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
25*b77af630Sdamjan #include "precompiled_scui.hxx"
26cdf0e10cSrcweir
27cdf0e10cSrcweir
28cdf0e10cSrcweir
29cdf0e10cSrcweir
30cdf0e10cSrcweir #include <vcl/msgbox.hxx>
31cdf0e10cSrcweir #include <i18npool/mslangid.hxx>
32cdf0e10cSrcweir #include <svtools/collatorres.hxx>
33cdf0e10cSrcweir #include <unotools/collatorwrapper.hxx>
34cdf0e10cSrcweir #include <unotools/localedatawrapper.hxx>
35cdf0e10cSrcweir #include <comphelper/processfactory.hxx>
36cdf0e10cSrcweir
37cdf0e10cSrcweir #include "scitems.hxx"
38cdf0e10cSrcweir #include "uiitems.hxx"
39cdf0e10cSrcweir #include "viewdata.hxx"
40cdf0e10cSrcweir #include "document.hxx"
41cdf0e10cSrcweir #include "global.hxx"
42cdf0e10cSrcweir #include "dbcolect.hxx"
43cdf0e10cSrcweir #include "userlist.hxx"
44cdf0e10cSrcweir #include "rangeutl.hxx"
45cdf0e10cSrcweir #include "scresid.hxx"
46cdf0e10cSrcweir #include "sc.hrc" // -> Slot IDs
47cdf0e10cSrcweir #include "globstr.hrc"
48cdf0e10cSrcweir
49cdf0e10cSrcweir #include "sortdlg.hxx"
50cdf0e10cSrcweir #include "sortdlg.hrc"
51cdf0e10cSrcweir
52cdf0e10cSrcweir #define _TPSORT_CXX
53cdf0e10cSrcweir #include "tpsort.hxx"
54cdf0e10cSrcweir #undef _TPSORT_CXX
55cdf0e10cSrcweir
56cdf0e10cSrcweir using namespace com::sun::star;
57cdf0e10cSrcweir
58cdf0e10cSrcweir // STATIC DATA -----------------------------------------------------------
59cdf0e10cSrcweir
60cdf0e10cSrcweir static sal_uInt16 pSortRanges[] =
61cdf0e10cSrcweir {
62cdf0e10cSrcweir SID_SORT,
63cdf0e10cSrcweir SID_SORT,
64cdf0e10cSrcweir 0
65cdf0e10cSrcweir };
66cdf0e10cSrcweir
67cdf0e10cSrcweir // -----------------------------------------------------------------------
68cdf0e10cSrcweir
69cdf0e10cSrcweir /*
70cdf0e10cSrcweir * Da sich Einstellungen auf der zweiten TabPage (Optionen) auf
71cdf0e10cSrcweir * die erste TabPage auswirken, muss es die Moeglichkeit geben,
72cdf0e10cSrcweir * dies der jeweils anderen Seite mitzuteilen.
73cdf0e10cSrcweir *
74cdf0e10cSrcweir * Im Moment wird dieses Problem ueber zwei Datenmember des TabDialoges
75cdf0e10cSrcweir * geloest. Wird eine Seite Aktiviert/Deaktiviert, so gleicht sie diese
76cdf0e10cSrcweir * Datenmember mit dem eigenen Zustand ab (->Activate()/Deactivate()).
77cdf0e10cSrcweir *
78cdf0e10cSrcweir * 31.01.95:
79cdf0e10cSrcweir * Die Klasse SfxTabPage bietet mittlerweile ein Verfahren an:
80cdf0e10cSrcweir *
81cdf0e10cSrcweir * virtual sal_Bool HasExchangeSupport() const; -> return sal_True;
82cdf0e10cSrcweir * virtual void ActivatePage(const SfxItemSet &);
83cdf0e10cSrcweir * virtual int DeactivatePage(SfxItemSet * = 0);
84cdf0e10cSrcweir *
85cdf0e10cSrcweir * muss noch geaendert werden!
86cdf0e10cSrcweir */
87cdf0e10cSrcweir
88cdf0e10cSrcweir //========================================================================
89cdf0e10cSrcweir //========================================================================
90cdf0e10cSrcweir // Sortierkriterien-Tabpage:
91cdf0e10cSrcweir
ScTabPageSortFields(Window * pParent,const SfxItemSet & rArgSet)92cdf0e10cSrcweir ScTabPageSortFields::ScTabPageSortFields( Window* pParent,
93cdf0e10cSrcweir const SfxItemSet& rArgSet )
94cdf0e10cSrcweir
95cdf0e10cSrcweir : SfxTabPage ( pParent,
96cdf0e10cSrcweir ScResId( RID_SCPAGE_SORT_FIELDS ),
97cdf0e10cSrcweir rArgSet ),
98cdf0e10cSrcweir //
99cdf0e10cSrcweir aFlSort1 ( this, ScResId( FL_SORT1 ) ),
100cdf0e10cSrcweir aLbSort1 ( this, ScResId( LB_SORT1 ) ),
101cdf0e10cSrcweir aBtnUp1 ( this, ScResId( BTN_UP1 ) ),
102cdf0e10cSrcweir aBtnDown1 ( this, ScResId( BTN_DOWN1 ) ),
103cdf0e10cSrcweir //
104cdf0e10cSrcweir aFlSort2 ( this, ScResId( FL_SORT2 ) ),
105cdf0e10cSrcweir aLbSort2 ( this, ScResId( LB_SORT2 ) ),
106cdf0e10cSrcweir aBtnUp2 ( this, ScResId( BTN_UP2 ) ),
107cdf0e10cSrcweir aBtnDown2 ( this, ScResId( BTN_DOWN2 ) ),
108cdf0e10cSrcweir //
109cdf0e10cSrcweir aFlSort3 ( this, ScResId( FL_SORT3 ) ),
110cdf0e10cSrcweir aLbSort3 ( this, ScResId( LB_SORT3 ) ),
111cdf0e10cSrcweir aBtnUp3 ( this, ScResId( BTN_UP3 ) ),
112cdf0e10cSrcweir aBtnDown3 ( this, ScResId( BTN_DOWN3 ) ),
113cdf0e10cSrcweir
114cdf0e10cSrcweir aStrUndefined ( ScResId( SCSTR_UNDEFINED ) ),
115cdf0e10cSrcweir aStrColumn ( ScResId( SCSTR_COLUMN ) ),
116cdf0e10cSrcweir aStrRow ( ScResId( SCSTR_ROW ) ),
117cdf0e10cSrcweir //
118cdf0e10cSrcweir nWhichSort ( rArgSet.GetPool()->GetWhich( SID_SORT ) ),
119cdf0e10cSrcweir pDlg ( (ScSortDlg*)(GetParent()->GetParent()) ),
120cdf0e10cSrcweir pViewData ( NULL ),
121cdf0e10cSrcweir rSortData ( ((const ScSortItem&)
122cdf0e10cSrcweir rArgSet.Get( nWhichSort )).
123cdf0e10cSrcweir GetSortData() ),
124cdf0e10cSrcweir nFieldCount ( 0 ),
125cdf0e10cSrcweir bHasHeader ( sal_False ),
126cdf0e10cSrcweir bSortByRows ( sal_False )
127cdf0e10cSrcweir {
128cdf0e10cSrcweir Init();
129cdf0e10cSrcweir FreeResource();
130cdf0e10cSrcweir SetExchangeSupport();
131cdf0e10cSrcweir }
132cdf0e10cSrcweir
133cdf0e10cSrcweir // -----------------------------------------------------------------------
134cdf0e10cSrcweir
~ScTabPageSortFields()135cdf0e10cSrcweir __EXPORT ScTabPageSortFields::~ScTabPageSortFields()
136cdf0e10cSrcweir {
137cdf0e10cSrcweir }
138cdf0e10cSrcweir
139cdf0e10cSrcweir // -----------------------------------------------------------------------
140cdf0e10cSrcweir
Init()141cdf0e10cSrcweir void ScTabPageSortFields::Init()
142cdf0e10cSrcweir {
143cdf0e10cSrcweir const ScSortItem& rSortItem = (const ScSortItem&)
144cdf0e10cSrcweir GetItemSet().Get( nWhichSort );
145cdf0e10cSrcweir
146cdf0e10cSrcweir pViewData = rSortItem.GetViewData();
147cdf0e10cSrcweir
148cdf0e10cSrcweir DBG_ASSERT( pViewData, "ViewData not found!" );
149cdf0e10cSrcweir
150cdf0e10cSrcweir nFieldArr[0] = 0;
151cdf0e10cSrcweir nFirstCol = 0;
152cdf0e10cSrcweir nFirstRow = 0;
153cdf0e10cSrcweir
154cdf0e10cSrcweir aLbSort1.SetSelectHdl( LINK( this, ScTabPageSortFields, SelectHdl ) );
155cdf0e10cSrcweir aLbSort2.SetSelectHdl( LINK( this, ScTabPageSortFields, SelectHdl ) );
156cdf0e10cSrcweir aLbSort3.SetSelectHdl( LINK( this, ScTabPageSortFields, SelectHdl ) );
157cdf0e10cSrcweir aLbSort1.Clear();
158cdf0e10cSrcweir aLbSort2.Clear();
159cdf0e10cSrcweir aLbSort3.Clear();
160cdf0e10cSrcweir
161cdf0e10cSrcweir aSortLbArr[0] = &aLbSort1;
162cdf0e10cSrcweir aSortLbArr[1] = &aLbSort2;
163cdf0e10cSrcweir aSortLbArr[2] = &aLbSort3;
164cdf0e10cSrcweir aDirBtnArr[0][0] = &aBtnUp1;
165cdf0e10cSrcweir aDirBtnArr[0][1] = &aBtnDown1;
166cdf0e10cSrcweir aDirBtnArr[1][0] = &aBtnUp2;
167cdf0e10cSrcweir aDirBtnArr[1][1] = &aBtnDown2;
168cdf0e10cSrcweir aDirBtnArr[2][0] = &aBtnUp3;
169cdf0e10cSrcweir aDirBtnArr[2][1] = &aBtnDown3;
170cdf0e10cSrcweir aFlArr[0] = &aFlSort1;
171cdf0e10cSrcweir aFlArr[1] = &aFlSort2;
172cdf0e10cSrcweir aFlArr[2] = &aFlSort3;
173cdf0e10cSrcweir }
174cdf0e10cSrcweir
175cdf0e10cSrcweir //------------------------------------------------------------------------
176cdf0e10cSrcweir
GetRanges()177cdf0e10cSrcweir sal_uInt16* __EXPORT ScTabPageSortFields::GetRanges()
178cdf0e10cSrcweir {
179cdf0e10cSrcweir return pSortRanges;
180cdf0e10cSrcweir }
181cdf0e10cSrcweir
182cdf0e10cSrcweir // -----------------------------------------------------------------------
183cdf0e10cSrcweir
Create(Window * pParent,const SfxItemSet & rArgSet)184cdf0e10cSrcweir SfxTabPage* __EXPORT ScTabPageSortFields::Create( Window* pParent,
185cdf0e10cSrcweir const SfxItemSet& rArgSet )
186cdf0e10cSrcweir {
187cdf0e10cSrcweir return ( new ScTabPageSortFields( pParent, rArgSet ) );
188cdf0e10cSrcweir }
189cdf0e10cSrcweir
190cdf0e10cSrcweir // -----------------------------------------------------------------------
191cdf0e10cSrcweir
Reset(const SfxItemSet &)192cdf0e10cSrcweir void __EXPORT ScTabPageSortFields::Reset( const SfxItemSet& /* rArgSet */ )
193cdf0e10cSrcweir {
194cdf0e10cSrcweir bSortByRows = rSortData.bByRow;
195cdf0e10cSrcweir bHasHeader = rSortData.bHasHeader;
196cdf0e10cSrcweir
197cdf0e10cSrcweir if ( aLbSort1.GetEntryCount() == 0 )
198cdf0e10cSrcweir FillFieldLists();
199cdf0e10cSrcweir
200cdf0e10cSrcweir // Selektieren der ListBoxen:
201cdf0e10cSrcweir
202cdf0e10cSrcweir if ( rSortData.bDoSort[0] )
203cdf0e10cSrcweir {
204cdf0e10cSrcweir for ( sal_uInt16 i=0; i<3; i++ )
205cdf0e10cSrcweir {
206cdf0e10cSrcweir if ( rSortData.bDoSort[i] )
207cdf0e10cSrcweir {
208cdf0e10cSrcweir aSortLbArr[i]->SelectEntryPos(
209cdf0e10cSrcweir GetFieldSelPos( rSortData.nField[i] ) );
210cdf0e10cSrcweir
211cdf0e10cSrcweir (rSortData.bAscending[i])
212cdf0e10cSrcweir ? aDirBtnArr[i][0]->Check() // Up
213cdf0e10cSrcweir : aDirBtnArr[i][1]->Check(); // Down
214cdf0e10cSrcweir }
215cdf0e10cSrcweir else
216cdf0e10cSrcweir {
217cdf0e10cSrcweir aSortLbArr[i]->SelectEntryPos( 0 ); // "keiner" selektieren
218cdf0e10cSrcweir aDirBtnArr[i][0]->Check(); // Up
219cdf0e10cSrcweir }
220cdf0e10cSrcweir }
221cdf0e10cSrcweir
222cdf0e10cSrcweir EnableField( 1 );
223cdf0e10cSrcweir EnableField( 2 );
224cdf0e10cSrcweir EnableField( 3 );
225cdf0e10cSrcweir if ( aLbSort1.GetSelectEntryPos() == 0 )
226cdf0e10cSrcweir DisableField( 2 );
227cdf0e10cSrcweir if ( aLbSort2.GetSelectEntryPos() == 0 )
228cdf0e10cSrcweir DisableField( 3 );
229cdf0e10cSrcweir }
230cdf0e10cSrcweir else
231cdf0e10cSrcweir {
232cdf0e10cSrcweir SCCOL nCol = pViewData->GetCurX();
233cdf0e10cSrcweir
234cdf0e10cSrcweir if( nCol < rSortData.nCol1 )
235cdf0e10cSrcweir nCol = rSortData.nCol1;
236cdf0e10cSrcweir else if( nCol > rSortData.nCol2 )
237cdf0e10cSrcweir nCol = rSortData.nCol2;
238cdf0e10cSrcweir
239cdf0e10cSrcweir sal_uInt16 nSort1Pos = nCol - rSortData.nCol1+1;
240cdf0e10cSrcweir aLbSort1.SelectEntryPos( nSort1Pos );
241cdf0e10cSrcweir aLbSort2.SelectEntryPos( 0 );
242cdf0e10cSrcweir aLbSort3.SelectEntryPos( 0 );
243cdf0e10cSrcweir aBtnUp1.Check();
244cdf0e10cSrcweir aBtnUp2.Check();
245cdf0e10cSrcweir aBtnUp3.Check();
246cdf0e10cSrcweir EnableField ( 1 );
247cdf0e10cSrcweir EnableField ( 2 );
248cdf0e10cSrcweir DisableField( 3 );
249cdf0e10cSrcweir }
250cdf0e10cSrcweir
251cdf0e10cSrcweir if ( pDlg )
252cdf0e10cSrcweir {
253cdf0e10cSrcweir pDlg->SetByRows ( bSortByRows );
254cdf0e10cSrcweir pDlg->SetHeaders( bHasHeader );
255cdf0e10cSrcweir }
256cdf0e10cSrcweir }
257cdf0e10cSrcweir
258cdf0e10cSrcweir // -----------------------------------------------------------------------
259cdf0e10cSrcweir
FillItemSet(SfxItemSet & rArgSet)260cdf0e10cSrcweir sal_Bool __EXPORT ScTabPageSortFields::FillItemSet( SfxItemSet& rArgSet )
261cdf0e10cSrcweir {
262cdf0e10cSrcweir ScSortParam theSortData = rSortData;
263cdf0e10cSrcweir if (pDlg)
264cdf0e10cSrcweir {
265cdf0e10cSrcweir const SfxItemSet* pExample = pDlg->GetExampleSet();
266cdf0e10cSrcweir const SfxPoolItem* pItem;
267cdf0e10cSrcweir if ( pExample && pExample->GetItemState( nWhichSort, sal_True, &pItem ) == SFX_ITEM_SET )
268cdf0e10cSrcweir theSortData = ((const ScSortItem*)pItem)->GetSortData();
269cdf0e10cSrcweir }
270cdf0e10cSrcweir
271cdf0e10cSrcweir sal_uInt16 nSort1Pos = aLbSort1.GetSelectEntryPos();
272cdf0e10cSrcweir sal_uInt16 nSort2Pos = aLbSort2.GetSelectEntryPos();
273cdf0e10cSrcweir sal_uInt16 nSort3Pos = aLbSort3.GetSelectEntryPos();
274cdf0e10cSrcweir
275cdf0e10cSrcweir DBG_ASSERT( (nSort1Pos <= SC_MAXFIELDS)
276cdf0e10cSrcweir && (nSort2Pos <= SC_MAXFIELDS)
277cdf0e10cSrcweir && (nSort3Pos <= SC_MAXFIELDS),
278cdf0e10cSrcweir "Array-Range Fehler!" );
279cdf0e10cSrcweir
280cdf0e10cSrcweir if ( nSort1Pos == LISTBOX_ENTRY_NOTFOUND ) nSort1Pos = 0;
281cdf0e10cSrcweir if ( nSort2Pos == LISTBOX_ENTRY_NOTFOUND ) nSort2Pos = 0;
282cdf0e10cSrcweir if ( nSort3Pos == LISTBOX_ENTRY_NOTFOUND ) nSort3Pos = 0;
283cdf0e10cSrcweir
284cdf0e10cSrcweir if ( nSort1Pos > 0 )
285cdf0e10cSrcweir {
286cdf0e10cSrcweir theSortData.bDoSort[0] = (nSort1Pos > 0);
287cdf0e10cSrcweir theSortData.bDoSort[1] = (nSort2Pos > 0);
288cdf0e10cSrcweir theSortData.bDoSort[2] = (nSort3Pos > 0);
289cdf0e10cSrcweir
290cdf0e10cSrcweir // wenn auf Optionen-Seite "OK" gewaehlt wurde und
291cdf0e10cSrcweir // dabei die Sortierrichtung umgestellt wurde, so
292cdf0e10cSrcweir // wird das erste Feld der jeweiligen Richtung als
293cdf0e10cSrcweir // Sortierkriterium gewaehlt (steht in nFieldArr[0]):
294cdf0e10cSrcweir if ( bSortByRows != pDlg->GetByRows() )
295cdf0e10cSrcweir {
296cdf0e10cSrcweir theSortData.nField[0] =
297cdf0e10cSrcweir theSortData.nField[1] =
298cdf0e10cSrcweir theSortData.nField[2] = ( bSortByRows ?
299cdf0e10cSrcweir static_cast<SCCOLROW>(nFirstRow) :
300cdf0e10cSrcweir static_cast<SCCOLROW>(nFirstCol) );
301cdf0e10cSrcweir }
302cdf0e10cSrcweir else
303cdf0e10cSrcweir {
304cdf0e10cSrcweir theSortData.nField[0] = nFieldArr[nSort1Pos];
305cdf0e10cSrcweir theSortData.nField[1] = nFieldArr[nSort2Pos];
306cdf0e10cSrcweir theSortData.nField[2] = nFieldArr[nSort3Pos];
307cdf0e10cSrcweir }
308cdf0e10cSrcweir
309cdf0e10cSrcweir theSortData.bAscending[0] = aBtnUp1.IsChecked();
310cdf0e10cSrcweir theSortData.bAscending[1] = aBtnUp2.IsChecked();
311cdf0e10cSrcweir theSortData.bAscending[2] = aBtnUp3.IsChecked();
312cdf0e10cSrcweir // bHasHeader ist in ScTabPageSortOptions::FillItemSet, wo es hingehoert
313cdf0e10cSrcweir }
314cdf0e10cSrcweir else
315cdf0e10cSrcweir {
316cdf0e10cSrcweir theSortData.bDoSort[0] =
317cdf0e10cSrcweir theSortData.bDoSort[1] =
318cdf0e10cSrcweir theSortData.bDoSort[2] = sal_False;
319cdf0e10cSrcweir }
320cdf0e10cSrcweir
321cdf0e10cSrcweir rArgSet.Put( ScSortItem( SCITEM_SORTDATA, NULL, &theSortData ) );
322cdf0e10cSrcweir
323cdf0e10cSrcweir return sal_True;
324cdf0e10cSrcweir }
325cdf0e10cSrcweir
326cdf0e10cSrcweir // -----------------------------------------------------------------------
327cdf0e10cSrcweir
328cdf0e10cSrcweir // fuer Datenaustausch ohne Dialog-Umweg: (! noch zu tun !)
329cdf0e10cSrcweir // void ScTabPageSortFields::ActivatePage( const SfxItemSet& rSet )
330cdf0e10cSrcweir
ActivatePage()331cdf0e10cSrcweir void __EXPORT ScTabPageSortFields::ActivatePage()
332cdf0e10cSrcweir {
333cdf0e10cSrcweir if ( pDlg )
334cdf0e10cSrcweir {
335cdf0e10cSrcweir if ( bHasHeader != pDlg->GetHeaders()
336cdf0e10cSrcweir || bSortByRows != pDlg->GetByRows() )
337cdf0e10cSrcweir {
338cdf0e10cSrcweir sal_uInt16 nCurSel1 = aLbSort1.GetSelectEntryPos();
339cdf0e10cSrcweir sal_uInt16 nCurSel2 = aLbSort2.GetSelectEntryPos();
340cdf0e10cSrcweir sal_uInt16 nCurSel3 = aLbSort3.GetSelectEntryPos();
341cdf0e10cSrcweir
342cdf0e10cSrcweir bHasHeader = pDlg->GetHeaders();
343cdf0e10cSrcweir bSortByRows = pDlg->GetByRows();
344cdf0e10cSrcweir FillFieldLists();
345cdf0e10cSrcweir aLbSort1.SelectEntryPos( nCurSel1 );
346cdf0e10cSrcweir aLbSort2.SelectEntryPos( nCurSel2 );
347cdf0e10cSrcweir aLbSort3.SelectEntryPos( nCurSel3 );
348cdf0e10cSrcweir }
349cdf0e10cSrcweir }
350cdf0e10cSrcweir }
351cdf0e10cSrcweir
352cdf0e10cSrcweir // -----------------------------------------------------------------------
353cdf0e10cSrcweir
DeactivatePage(SfxItemSet * pSetP)354cdf0e10cSrcweir int __EXPORT ScTabPageSortFields::DeactivatePage( SfxItemSet* pSetP )
355cdf0e10cSrcweir {
356cdf0e10cSrcweir if ( pDlg )
357cdf0e10cSrcweir {
358cdf0e10cSrcweir if ( bHasHeader != pDlg->GetHeaders() )
359cdf0e10cSrcweir pDlg->SetHeaders( bHasHeader );
360cdf0e10cSrcweir
361cdf0e10cSrcweir if ( bSortByRows != pDlg->GetByRows() )
362cdf0e10cSrcweir pDlg->SetByRows( bSortByRows );
363cdf0e10cSrcweir }
364cdf0e10cSrcweir
365cdf0e10cSrcweir if ( pSetP )
366cdf0e10cSrcweir FillItemSet( *pSetP );
367cdf0e10cSrcweir
368cdf0e10cSrcweir return SfxTabPage::LEAVE_PAGE;
369cdf0e10cSrcweir }
370cdf0e10cSrcweir
371cdf0e10cSrcweir // -----------------------------------------------------------------------
372cdf0e10cSrcweir
DisableField(sal_uInt16 nField)373cdf0e10cSrcweir void ScTabPageSortFields::DisableField( sal_uInt16 nField )
374cdf0e10cSrcweir {
375cdf0e10cSrcweir nField--;
376cdf0e10cSrcweir
377cdf0e10cSrcweir if ( nField<=2 )
378cdf0e10cSrcweir {
379cdf0e10cSrcweir aSortLbArr[nField] ->Disable();
380cdf0e10cSrcweir aDirBtnArr[nField][0]->Disable();
381cdf0e10cSrcweir aDirBtnArr[nField][1]->Disable();
382cdf0e10cSrcweir aFlArr[nField] ->Disable();
383cdf0e10cSrcweir }
384cdf0e10cSrcweir }
385cdf0e10cSrcweir
386cdf0e10cSrcweir // -----------------------------------------------------------------------
387cdf0e10cSrcweir
EnableField(sal_uInt16 nField)388cdf0e10cSrcweir void ScTabPageSortFields::EnableField( sal_uInt16 nField )
389cdf0e10cSrcweir {
390cdf0e10cSrcweir nField--;
391cdf0e10cSrcweir
392cdf0e10cSrcweir if ( nField<=2 )
393cdf0e10cSrcweir {
394cdf0e10cSrcweir aSortLbArr[nField] ->Enable();
395cdf0e10cSrcweir aDirBtnArr[nField][0]->Enable();
396cdf0e10cSrcweir aDirBtnArr[nField][1]->Enable();
397cdf0e10cSrcweir aFlArr[nField] ->Enable();
398cdf0e10cSrcweir }
399cdf0e10cSrcweir }
400cdf0e10cSrcweir
401cdf0e10cSrcweir // -----------------------------------------------------------------------
402cdf0e10cSrcweir
FillFieldLists()403cdf0e10cSrcweir void ScTabPageSortFields::FillFieldLists()
404cdf0e10cSrcweir {
405cdf0e10cSrcweir if ( pViewData )
406cdf0e10cSrcweir {
407cdf0e10cSrcweir ScDocument* pDoc = pViewData->GetDocument();
408cdf0e10cSrcweir
409cdf0e10cSrcweir if ( pDoc )
410cdf0e10cSrcweir {
411cdf0e10cSrcweir aLbSort1.Clear();
412cdf0e10cSrcweir aLbSort2.Clear();
413cdf0e10cSrcweir aLbSort3.Clear();
414cdf0e10cSrcweir aLbSort1.InsertEntry( aStrUndefined, 0 );
415cdf0e10cSrcweir aLbSort2.InsertEntry( aStrUndefined, 0 );
416cdf0e10cSrcweir aLbSort3.InsertEntry( aStrUndefined, 0 );
417cdf0e10cSrcweir
418cdf0e10cSrcweir SCCOL nFirstSortCol = rSortData.nCol1;
419cdf0e10cSrcweir SCROW nFirstSortRow = rSortData.nRow1;
420cdf0e10cSrcweir SCTAB nTab = pViewData->GetTabNo();
421cdf0e10cSrcweir sal_uInt16 i = 1;
422cdf0e10cSrcweir
423cdf0e10cSrcweir if ( bSortByRows )
424cdf0e10cSrcweir {
425cdf0e10cSrcweir String aFieldName;
426cdf0e10cSrcweir SCCOL nMaxCol = rSortData.nCol2;
427cdf0e10cSrcweir SCCOL col;
428cdf0e10cSrcweir
429cdf0e10cSrcweir for ( col=nFirstSortCol; col<=nMaxCol && i<SC_MAXFIELDS; col++ )
430cdf0e10cSrcweir {
431cdf0e10cSrcweir pDoc->GetString( col, nFirstSortRow, nTab, aFieldName );
432cdf0e10cSrcweir if ( !bHasHeader || (aFieldName.Len() == 0) )
433cdf0e10cSrcweir {
434cdf0e10cSrcweir aFieldName = aStrColumn;
435cdf0e10cSrcweir aFieldName += ' ';
436cdf0e10cSrcweir aFieldName += ScColToAlpha( col );
437cdf0e10cSrcweir }
438cdf0e10cSrcweir nFieldArr[i] = col;
439cdf0e10cSrcweir aLbSort1.InsertEntry( aFieldName, i );
440cdf0e10cSrcweir aLbSort2.InsertEntry( aFieldName, i );
441cdf0e10cSrcweir aLbSort3.InsertEntry( aFieldName, i );
442cdf0e10cSrcweir i++;
443cdf0e10cSrcweir }
444cdf0e10cSrcweir }
445cdf0e10cSrcweir else
446cdf0e10cSrcweir {
447cdf0e10cSrcweir String aFieldName;
448cdf0e10cSrcweir SCROW nMaxRow = rSortData.nRow2;
449cdf0e10cSrcweir SCROW row;
450cdf0e10cSrcweir
451cdf0e10cSrcweir for ( row=nFirstSortRow; row<=nMaxRow && i<SC_MAXFIELDS; row++ )
452cdf0e10cSrcweir {
453cdf0e10cSrcweir pDoc->GetString( nFirstSortCol, row, nTab, aFieldName );
454cdf0e10cSrcweir if ( !bHasHeader || (aFieldName.Len() == 0) )
455cdf0e10cSrcweir {
456cdf0e10cSrcweir aFieldName = aStrRow;
457cdf0e10cSrcweir aFieldName += ' ';
458cdf0e10cSrcweir aFieldName += String::CreateFromInt32( row+1 );
459cdf0e10cSrcweir }
460cdf0e10cSrcweir nFieldArr[i] = row;
461cdf0e10cSrcweir aLbSort1.InsertEntry( aFieldName, i );
462cdf0e10cSrcweir aLbSort2.InsertEntry( aFieldName, i );
463cdf0e10cSrcweir aLbSort3.InsertEntry( aFieldName, i );
464cdf0e10cSrcweir i++;
465cdf0e10cSrcweir }
466cdf0e10cSrcweir }
467cdf0e10cSrcweir nFieldCount = i;
468cdf0e10cSrcweir }
469cdf0e10cSrcweir }
470cdf0e10cSrcweir }
471cdf0e10cSrcweir
472cdf0e10cSrcweir //------------------------------------------------------------------------
473cdf0e10cSrcweir
GetFieldSelPos(SCCOLROW nField)474cdf0e10cSrcweir sal_uInt16 ScTabPageSortFields::GetFieldSelPos( SCCOLROW nField )
475cdf0e10cSrcweir {
476cdf0e10cSrcweir sal_uInt16 nFieldPos = 0;
477cdf0e10cSrcweir sal_Bool bFound = sal_False;
478cdf0e10cSrcweir
479cdf0e10cSrcweir for ( sal_uInt16 n=1; n<nFieldCount && !bFound; n++ )
480cdf0e10cSrcweir {
481cdf0e10cSrcweir if ( nFieldArr[n] == nField )
482cdf0e10cSrcweir {
483cdf0e10cSrcweir nFieldPos = n;
484cdf0e10cSrcweir bFound = sal_True;
485cdf0e10cSrcweir }
486cdf0e10cSrcweir }
487cdf0e10cSrcweir
488cdf0e10cSrcweir return nFieldPos;
489cdf0e10cSrcweir }
490cdf0e10cSrcweir
491cdf0e10cSrcweir // -----------------------------------------------------------------------
492cdf0e10cSrcweir // Handler:
493cdf0e10cSrcweir //---------
494cdf0e10cSrcweir
IMPL_LINK(ScTabPageSortFields,SelectHdl,ListBox *,pLb)495cdf0e10cSrcweir IMPL_LINK( ScTabPageSortFields, SelectHdl, ListBox *, pLb )
496cdf0e10cSrcweir {
497cdf0e10cSrcweir String aSelEntry = pLb->GetSelectEntry();
498cdf0e10cSrcweir
499cdf0e10cSrcweir if ( pLb == &aLbSort1 )
500cdf0e10cSrcweir {
501cdf0e10cSrcweir if ( aSelEntry == aStrUndefined )
502cdf0e10cSrcweir {
503cdf0e10cSrcweir aLbSort2.SelectEntryPos( 0 );
504cdf0e10cSrcweir aLbSort3.SelectEntryPos( 0 );
505cdf0e10cSrcweir
506cdf0e10cSrcweir if ( aFlSort2.IsEnabled() )
507cdf0e10cSrcweir DisableField( 2 );
508cdf0e10cSrcweir
509cdf0e10cSrcweir if ( aFlSort3.IsEnabled() )
510cdf0e10cSrcweir DisableField( 3 );
511cdf0e10cSrcweir }
512cdf0e10cSrcweir else
513cdf0e10cSrcweir {
514cdf0e10cSrcweir if ( !aFlSort2.IsEnabled() )
515cdf0e10cSrcweir EnableField( 2 );
516cdf0e10cSrcweir }
517cdf0e10cSrcweir }
518cdf0e10cSrcweir else if ( pLb == &aLbSort2 )
519cdf0e10cSrcweir {
520cdf0e10cSrcweir if ( aSelEntry == aStrUndefined )
521cdf0e10cSrcweir {
522cdf0e10cSrcweir aLbSort3.SelectEntryPos( 0 );
523cdf0e10cSrcweir if ( aFlSort3.IsEnabled() )
524cdf0e10cSrcweir DisableField( 3 );
525cdf0e10cSrcweir }
526cdf0e10cSrcweir else
527cdf0e10cSrcweir {
528cdf0e10cSrcweir if ( !aFlSort3.IsEnabled() )
529cdf0e10cSrcweir EnableField( 3 );
530cdf0e10cSrcweir }
531cdf0e10cSrcweir }
532cdf0e10cSrcweir return 0;
533cdf0e10cSrcweir }
534cdf0e10cSrcweir
535cdf0e10cSrcweir //========================================================================
536cdf0e10cSrcweir // Sortieroptionen-Tabpage:
537cdf0e10cSrcweir //========================================================================
538cdf0e10cSrcweir
539cdf0e10cSrcweir #if ENABLE_LAYOUT_EXPERIMENTAL
540cdf0e10cSrcweir #include <layout/layout-pre.hxx>
541cdf0e10cSrcweir
542cdf0e10cSrcweir #if ENABLE_LAYOUT
543cdf0e10cSrcweir #undef ScResId
544cdf0e10cSrcweir #define ScResId(x) #x
545cdf0e10cSrcweir #undef SfxTabPage
546cdf0e10cSrcweir #define SfxTabPage( parent, id, args ) SfxTabPage( parent, "sort-options.xml", id, &args )
547cdf0e10cSrcweir #endif /* ENABLE_LAYOUT */
548cdf0e10cSrcweir
549cdf0e10cSrcweir #endif /* ENABLE_LAYOUT_EXPERIMENTAL */
550cdf0e10cSrcweir
ScTabPageSortOptions(Window * pParent,const SfxItemSet & rArgSet)551cdf0e10cSrcweir ScTabPageSortOptions::ScTabPageSortOptions( Window* pParent,
552cdf0e10cSrcweir const SfxItemSet& rArgSet )
553cdf0e10cSrcweir
554cdf0e10cSrcweir : SfxTabPage ( pParent,
555cdf0e10cSrcweir ScResId( RID_SCPAGE_SORT_OPTIONS ),
556cdf0e10cSrcweir rArgSet ),
557cdf0e10cSrcweir //
558cdf0e10cSrcweir aBtnCase ( this, ScResId( BTN_CASESENSITIVE ) ),
559cdf0e10cSrcweir aBtnHeader ( this, ScResId( BTN_LABEL ) ),
560cdf0e10cSrcweir aBtnFormats ( this, ScResId( BTN_FORMATS ) ),
561cdf0e10cSrcweir aBtnCopyResult ( this, ScResId( BTN_COPYRESULT ) ),
562cdf0e10cSrcweir aLbOutPos ( this, ScResId( LB_OUTAREA ) ),
563cdf0e10cSrcweir aEdOutPos ( this, ScResId( ED_OUTAREA ) ),
564cdf0e10cSrcweir aBtnSortUser ( this, ScResId( BTN_SORT_USER ) ),
565cdf0e10cSrcweir aLbSortUser ( this, ScResId( LB_SORT_USER ) ),
566cdf0e10cSrcweir aFtLanguage ( this, ScResId( FT_LANGUAGE ) ),
567cdf0e10cSrcweir aLbLanguage ( this, ScResId( LB_LANGUAGE ) ),
568cdf0e10cSrcweir aFtAlgorithm ( this, ScResId( FT_ALGORITHM ) ),
569cdf0e10cSrcweir aLbAlgorithm ( this, ScResId( LB_ALGORITHM ) ),
570cdf0e10cSrcweir aLineDirection ( this, ScResId( FL_DIRECTION ) ),
571cdf0e10cSrcweir aBtnTopDown ( this, ScResId( BTN_TOP_DOWN ) ),
572cdf0e10cSrcweir aBtnLeftRight ( this, ScResId( BTN_LEFT_RIGHT ) ),
573cdf0e10cSrcweir aFtAreaLabel ( this, ScResId( FT_AREA_LABEL ) ),
574cdf0e10cSrcweir // aFtArea ( this, ScResId( FT_AREA ) ),
575cdf0e10cSrcweir //
576cdf0e10cSrcweir #if ENABLE_LAYOUT_EXPERIMENTAL
577cdf0e10cSrcweir #undef this
578cdf0e10cSrcweir #undef ScResId
579cdf0e10cSrcweir #define ScResId(x) this, #x
580cdf0e10cSrcweir #endif /* ENABLE_LAYOUT_EXPERIMENTAL */
581cdf0e10cSrcweir aStrRowLabel ( ScResId( STR_ROW_LABEL ) ),
582cdf0e10cSrcweir aStrColLabel ( ScResId( STR_COL_LABEL ) ),
583cdf0e10cSrcweir aStrUndefined ( ScResId( SCSTR_UNDEFINED ) ),
584cdf0e10cSrcweir aStrNoName ( ScGlobal::GetRscString(STR_DB_NONAME) ),
585cdf0e10cSrcweir //
586cdf0e10cSrcweir nWhichSort ( rArgSet.GetPool()->GetWhich( SID_SORT ) ),
587cdf0e10cSrcweir rSortData ( ((const ScSortItem&)
588cdf0e10cSrcweir rArgSet.Get( nWhichSort )).GetSortData() ),
589cdf0e10cSrcweir pViewData ( NULL ),
590cdf0e10cSrcweir pDoc ( NULL ),
591cdf0e10cSrcweir pDlg ( (ScSortDlg*)(GetParent() ? GetParent()->GetParent() : 0 ) ),
592cdf0e10cSrcweir pColRes ( NULL ),
593cdf0e10cSrcweir pColWrap ( NULL )
594cdf0e10cSrcweir {
595cdf0e10cSrcweir Init();
596cdf0e10cSrcweir FreeResource();
597cdf0e10cSrcweir SetExchangeSupport();
598cdf0e10cSrcweir
599cdf0e10cSrcweir aLbOutPos.SetAccessibleRelationLabeledBy(&aBtnCopyResult);
600cdf0e10cSrcweir aLbOutPos.SetAccessibleName(aBtnCopyResult.GetText());
601cdf0e10cSrcweir aEdOutPos.SetAccessibleRelationLabeledBy(&aBtnCopyResult);
602cdf0e10cSrcweir aEdOutPos.SetAccessibleName(aBtnCopyResult.GetText());
603cdf0e10cSrcweir aLbSortUser.SetAccessibleRelationLabeledBy(&aBtnSortUser);
604cdf0e10cSrcweir aLbSortUser.SetAccessibleName(aBtnSortUser.GetText());
605cdf0e10cSrcweir }
606cdf0e10cSrcweir
607cdf0e10cSrcweir // -----------------------------------------------------------------------
608cdf0e10cSrcweir
~ScTabPageSortOptions()609cdf0e10cSrcweir __EXPORT ScTabPageSortOptions::~ScTabPageSortOptions()
610cdf0e10cSrcweir {
611cdf0e10cSrcweir sal_uInt16 nEntries = aLbOutPos.GetEntryCount();
612cdf0e10cSrcweir
613cdf0e10cSrcweir for ( sal_uInt16 i=1; i<nEntries; i++ )
614cdf0e10cSrcweir delete (String*)aLbOutPos.GetEntryData( i );
615cdf0e10cSrcweir
616cdf0e10cSrcweir delete pColRes;
617cdf0e10cSrcweir delete pColWrap; //! not if from document
618cdf0e10cSrcweir }
619cdf0e10cSrcweir
620cdf0e10cSrcweir // -----------------------------------------------------------------------
621cdf0e10cSrcweir
Init()622cdf0e10cSrcweir void ScTabPageSortOptions::Init()
623cdf0e10cSrcweir {
624cdf0e10cSrcweir aStrAreaLabel = aFtAreaLabel.GetText();
625cdf0e10cSrcweir aStrAreaLabel.Append( (sal_Unicode) ' ' );
626cdf0e10cSrcweir
627cdf0e10cSrcweir // CollatorRessource has user-visible names for sort algorithms
628cdf0e10cSrcweir pColRes = new CollatorRessource();
629cdf0e10cSrcweir
630cdf0e10cSrcweir //! use CollatorWrapper from document?
631cdf0e10cSrcweir pColWrap = new CollatorWrapper( comphelper::getProcessServiceFactory() );
632cdf0e10cSrcweir
633cdf0e10cSrcweir const ScSortItem& rSortItem = (const ScSortItem&)
634cdf0e10cSrcweir GetItemSet().Get( nWhichSort );
635cdf0e10cSrcweir
636cdf0e10cSrcweir aLbOutPos.SetSelectHdl ( LINK( this, ScTabPageSortOptions, SelOutPosHdl ) );
637cdf0e10cSrcweir aBtnCopyResult.SetClickHdl( LINK( this, ScTabPageSortOptions, EnableHdl ) );
638cdf0e10cSrcweir aBtnSortUser.SetClickHdl ( LINK( this, ScTabPageSortOptions, EnableHdl ) );
639cdf0e10cSrcweir aBtnTopDown.SetClickHdl ( LINK( this, ScTabPageSortOptions, SortDirHdl ) );
640cdf0e10cSrcweir aBtnLeftRight.SetClickHdl ( LINK( this, ScTabPageSortOptions, SortDirHdl ) );
641cdf0e10cSrcweir aLbLanguage.SetSelectHdl ( LINK( this, ScTabPageSortOptions, FillAlgorHdl ) );
642cdf0e10cSrcweir
643cdf0e10cSrcweir pViewData = rSortItem.GetViewData();
644cdf0e10cSrcweir pDoc = pViewData ? pViewData->GetDocument() : NULL;
645cdf0e10cSrcweir
646cdf0e10cSrcweir DBG_ASSERT( pViewData, "ViewData not found! :-/" );
647cdf0e10cSrcweir
648cdf0e10cSrcweir if ( pViewData && pDoc )
649cdf0e10cSrcweir {
650cdf0e10cSrcweir String theArea;
651cdf0e10cSrcweir ScDBCollection* pDBColl = pDoc->GetDBCollection();
652cdf0e10cSrcweir String theDbArea;
653cdf0e10cSrcweir String theDbName = aStrNoName;
654cdf0e10cSrcweir const SCTAB nCurTab = pViewData->GetTabNo();
655cdf0e10cSrcweir const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention();
656cdf0e10cSrcweir
657cdf0e10cSrcweir aLbOutPos.Clear();
658cdf0e10cSrcweir aLbOutPos.InsertEntry( aStrUndefined, 0 );
659cdf0e10cSrcweir aLbOutPos.Disable();
660cdf0e10cSrcweir
661cdf0e10cSrcweir ScAreaNameIterator aIter( pDoc );
662cdf0e10cSrcweir String aName;
663cdf0e10cSrcweir ScRange aRange;
664cdf0e10cSrcweir String aRefStr;
665cdf0e10cSrcweir while ( aIter.Next( aName, aRange ) )
666cdf0e10cSrcweir {
667cdf0e10cSrcweir sal_uInt16 nInsert = aLbOutPos.InsertEntry( aName );
668cdf0e10cSrcweir
669cdf0e10cSrcweir aRange.aStart.Format( aRefStr, SCA_ABS_3D, pDoc, eConv );
670cdf0e10cSrcweir aLbOutPos.SetEntryData( nInsert, new String( aRefStr ) );
671cdf0e10cSrcweir }
672cdf0e10cSrcweir
673cdf0e10cSrcweir aLbOutPos.SelectEntryPos( 0 );
674cdf0e10cSrcweir aEdOutPos.SetText( EMPTY_STRING );
675cdf0e10cSrcweir
676cdf0e10cSrcweir /*
677cdf0e10cSrcweir * Ueberpruefen, ob es sich bei dem uebergebenen
678cdf0e10cSrcweir * Bereich um einen Datenbankbereich handelt:
679cdf0e10cSrcweir */
680cdf0e10cSrcweir
681cdf0e10cSrcweir ScAddress aScAddress( rSortData.nCol1, rSortData.nRow1, nCurTab );
682cdf0e10cSrcweir ScRange( aScAddress,
683cdf0e10cSrcweir ScAddress( rSortData.nCol2, rSortData.nRow2, nCurTab )
684cdf0e10cSrcweir ).Format( theArea, SCR_ABS, pDoc, eConv );
685cdf0e10cSrcweir
686cdf0e10cSrcweir if ( pDBColl )
687cdf0e10cSrcweir {
688cdf0e10cSrcweir ScDBData* pDBData
689cdf0e10cSrcweir = pDBColl->GetDBAtArea( nCurTab,
690cdf0e10cSrcweir rSortData.nCol1, rSortData.nRow1,
691cdf0e10cSrcweir rSortData.nCol2, rSortData.nRow2 );
692cdf0e10cSrcweir if ( pDBData )
693cdf0e10cSrcweir {
694cdf0e10cSrcweir pDBData->GetName( theDbName );
695cdf0e10cSrcweir aBtnHeader.Check( pDBData->HasHeader() );
696cdf0e10cSrcweir }
697cdf0e10cSrcweir }
698cdf0e10cSrcweir
699cdf0e10cSrcweir theArea.AppendAscii(RTL_CONSTASCII_STRINGPARAM(" ("));
700cdf0e10cSrcweir theArea += theDbName;
701cdf0e10cSrcweir theArea += ')';
702cdf0e10cSrcweir
703cdf0e10cSrcweir //aFtArea.SetText( theArea );
704cdf0e10cSrcweir theArea.Insert( aStrAreaLabel, 0 );
705cdf0e10cSrcweir aFtAreaLabel.SetText( theArea );
706cdf0e10cSrcweir
707cdf0e10cSrcweir aBtnHeader.SetText( aStrColLabel );
708cdf0e10cSrcweir }
709cdf0e10cSrcweir
710cdf0e10cSrcweir FillUserSortListBox();
711cdf0e10cSrcweir
712cdf0e10cSrcweir // get available languages
713cdf0e10cSrcweir
714cdf0e10cSrcweir aLbLanguage.SetLanguageList( LANG_LIST_ALL | LANG_LIST_ONLY_KNOWN, sal_False );
715cdf0e10cSrcweir aLbLanguage.InsertLanguage( LANGUAGE_SYSTEM );
716cdf0e10cSrcweir }
717cdf0e10cSrcweir
718cdf0e10cSrcweir //------------------------------------------------------------------------
719cdf0e10cSrcweir
GetRanges()720cdf0e10cSrcweir sal_uInt16* __EXPORT ScTabPageSortOptions::GetRanges()
721cdf0e10cSrcweir {
722cdf0e10cSrcweir return pSortRanges;
723cdf0e10cSrcweir }
724cdf0e10cSrcweir
725cdf0e10cSrcweir // -----------------------------------------------------------------------
726cdf0e10cSrcweir
727cdf0e10cSrcweir #if ENABLE_LAYOUT_EXPERIMENTAL
728cdf0e10cSrcweir #undef SfxTabPage
729cdf0e10cSrcweir #endif /* ENABLE_LAYOUT_EXPERIMENTAL */
Create(Window * pParent,const SfxItemSet & rArgSet)730cdf0e10cSrcweir SfxTabPage* __EXPORT ScTabPageSortOptions::Create(
731cdf0e10cSrcweir Window* pParent,
732cdf0e10cSrcweir const SfxItemSet& rArgSet )
733cdf0e10cSrcweir {
734cdf0e10cSrcweir return ( new ScTabPageSortOptions( pParent, rArgSet ) );
735cdf0e10cSrcweir }
736cdf0e10cSrcweir
737cdf0e10cSrcweir // -----------------------------------------------------------------------
738cdf0e10cSrcweir
Reset(const SfxItemSet &)739cdf0e10cSrcweir void __EXPORT ScTabPageSortOptions::Reset( const SfxItemSet& /* rArgSet */ )
740cdf0e10cSrcweir {
741cdf0e10cSrcweir if ( rSortData.bUserDef )
742cdf0e10cSrcweir {
743cdf0e10cSrcweir aBtnSortUser.Check( sal_True );
744cdf0e10cSrcweir aLbSortUser.Enable();
745cdf0e10cSrcweir aLbSortUser.SelectEntryPos( rSortData.nUserIndex );
746cdf0e10cSrcweir }
747cdf0e10cSrcweir else
748cdf0e10cSrcweir {
749cdf0e10cSrcweir aBtnSortUser.Check( sal_False );
750cdf0e10cSrcweir aLbSortUser.Disable();
751cdf0e10cSrcweir aLbSortUser.SelectEntryPos( 0 );
752cdf0e10cSrcweir }
753cdf0e10cSrcweir
754cdf0e10cSrcweir aBtnCase.Check ( rSortData.bCaseSens );
755cdf0e10cSrcweir aBtnFormats.Check ( rSortData.bIncludePattern );
756cdf0e10cSrcweir aBtnHeader.Check ( rSortData.bHasHeader );
757cdf0e10cSrcweir
758cdf0e10cSrcweir if ( rSortData.bByRow )
759cdf0e10cSrcweir {
760cdf0e10cSrcweir aBtnTopDown.Check();
761cdf0e10cSrcweir aBtnHeader.SetText( aStrColLabel );
762cdf0e10cSrcweir }
763cdf0e10cSrcweir else
764cdf0e10cSrcweir {
765cdf0e10cSrcweir aBtnLeftRight.Check();
766cdf0e10cSrcweir aBtnHeader.SetText( aStrRowLabel );
767cdf0e10cSrcweir }
768cdf0e10cSrcweir
769cdf0e10cSrcweir LanguageType eLang = MsLangId::convertLocaleToLanguage( rSortData.aCollatorLocale );
770cdf0e10cSrcweir if ( eLang == LANGUAGE_DONTKNOW )
771cdf0e10cSrcweir eLang = LANGUAGE_SYSTEM;
772cdf0e10cSrcweir aLbLanguage.SelectLanguage( eLang );
773cdf0e10cSrcweir FillAlgorHdl( &aLbLanguage ); // get algorithms, select default
774cdf0e10cSrcweir if ( rSortData.aCollatorAlgorithm.Len() )
775cdf0e10cSrcweir aLbAlgorithm.SelectEntry( pColRes->GetTranslation( rSortData.aCollatorAlgorithm ) );
776cdf0e10cSrcweir
777cdf0e10cSrcweir if ( pDoc && !rSortData.bInplace )
778cdf0e10cSrcweir {
779cdf0e10cSrcweir String aStr;
780cdf0e10cSrcweir sal_uInt16 nFormat = (rSortData.nDestTab != pViewData->GetTabNo())
781cdf0e10cSrcweir ? SCR_ABS_3D
782cdf0e10cSrcweir : SCR_ABS;
783cdf0e10cSrcweir
784cdf0e10cSrcweir theOutPos.Set( rSortData.nDestCol,
785cdf0e10cSrcweir rSortData.nDestRow,
786cdf0e10cSrcweir rSortData.nDestTab );
787cdf0e10cSrcweir
788cdf0e10cSrcweir theOutPos.Format( aStr, nFormat, pDoc, pDoc->GetAddressConvention() );
789cdf0e10cSrcweir aBtnCopyResult.Check();
790cdf0e10cSrcweir aLbOutPos.Enable();
791cdf0e10cSrcweir aEdOutPos.Enable();
792cdf0e10cSrcweir aEdOutPos.SetText( aStr );
793cdf0e10cSrcweir EdOutPosModHdl( &aEdOutPos );
794cdf0e10cSrcweir aEdOutPos.GrabFocus();
795cdf0e10cSrcweir aEdOutPos.SetSelection( Selection( 0, SELECTION_MAX ) );
796cdf0e10cSrcweir }
797cdf0e10cSrcweir else
798cdf0e10cSrcweir {
799cdf0e10cSrcweir aBtnCopyResult.Check( sal_False );
800cdf0e10cSrcweir aLbOutPos.Disable();
801cdf0e10cSrcweir aEdOutPos.Disable();
802cdf0e10cSrcweir aEdOutPos.SetText( EMPTY_STRING );
803cdf0e10cSrcweir }
804cdf0e10cSrcweir }
805cdf0e10cSrcweir
806cdf0e10cSrcweir // -----------------------------------------------------------------------
807cdf0e10cSrcweir
FillItemSet(SfxItemSet & rArgSet)808cdf0e10cSrcweir sal_Bool __EXPORT ScTabPageSortOptions::FillItemSet( SfxItemSet& rArgSet )
809cdf0e10cSrcweir {
810cdf0e10cSrcweir ScSortParam theSortData = rSortData;
811cdf0e10cSrcweir if (pDlg)
812cdf0e10cSrcweir {
813cdf0e10cSrcweir const SfxItemSet* pExample = pDlg->GetExampleSet();
814cdf0e10cSrcweir const SfxPoolItem* pItem;
815cdf0e10cSrcweir if ( pExample && pExample->GetItemState( nWhichSort, sal_True, &pItem ) == SFX_ITEM_SET )
816cdf0e10cSrcweir theSortData = ((const ScSortItem*)pItem)->GetSortData();
817cdf0e10cSrcweir }
818cdf0e10cSrcweir
819cdf0e10cSrcweir theSortData.bByRow = aBtnTopDown.IsChecked();
820cdf0e10cSrcweir theSortData.bHasHeader = aBtnHeader.IsChecked();
821cdf0e10cSrcweir theSortData.bCaseSens = aBtnCase.IsChecked();
822cdf0e10cSrcweir theSortData.bIncludePattern = aBtnFormats.IsChecked();
823cdf0e10cSrcweir theSortData.bInplace = !aBtnCopyResult.IsChecked();
824cdf0e10cSrcweir theSortData.nDestCol = theOutPos.Col();
825cdf0e10cSrcweir theSortData.nDestRow = theOutPos.Row();
826cdf0e10cSrcweir theSortData.nDestTab = theOutPos.Tab();
827cdf0e10cSrcweir theSortData.bUserDef = aBtnSortUser.IsChecked();
828cdf0e10cSrcweir theSortData.nUserIndex = (aBtnSortUser.IsChecked())
829cdf0e10cSrcweir ? aLbSortUser.GetSelectEntryPos()
830cdf0e10cSrcweir : 0;
831cdf0e10cSrcweir
832cdf0e10cSrcweir // get locale
833cdf0e10cSrcweir LanguageType eLang = aLbLanguage.GetSelectLanguage();
834cdf0e10cSrcweir theSortData.aCollatorLocale = MsLangId::convertLanguageToLocale( eLang, false );
835cdf0e10cSrcweir
836cdf0e10cSrcweir // get algorithm
837cdf0e10cSrcweir String sAlg;
838cdf0e10cSrcweir if ( eLang != LANGUAGE_SYSTEM )
839cdf0e10cSrcweir {
840cdf0e10cSrcweir uno::Sequence<rtl::OUString> aAlgos = pColWrap->listCollatorAlgorithms(
841cdf0e10cSrcweir theSortData.aCollatorLocale );
842cdf0e10cSrcweir sal_uInt16 nSel = aLbAlgorithm.GetSelectEntryPos();
843cdf0e10cSrcweir if ( nSel < aAlgos.getLength() )
844cdf0e10cSrcweir sAlg = aAlgos[nSel];
845cdf0e10cSrcweir }
846cdf0e10cSrcweir theSortData.aCollatorAlgorithm = sAlg;
847cdf0e10cSrcweir
848cdf0e10cSrcweir rArgSet.Put( ScSortItem( SCITEM_SORTDATA, &theSortData ) );
849cdf0e10cSrcweir
850cdf0e10cSrcweir return sal_True;
851cdf0e10cSrcweir }
852cdf0e10cSrcweir
853cdf0e10cSrcweir // -----------------------------------------------------------------------
854cdf0e10cSrcweir
855cdf0e10cSrcweir // fuer Datenaustausch ohne Dialog-Umweg: (! noch zu tun !)
856cdf0e10cSrcweir // void ScTabPageSortOptions::ActivatePage( const SfxItemSet& rSet )
ActivatePage()857cdf0e10cSrcweir void __EXPORT ScTabPageSortOptions::ActivatePage()
858cdf0e10cSrcweir {
859cdf0e10cSrcweir if ( pDlg )
860cdf0e10cSrcweir {
861cdf0e10cSrcweir if ( aBtnHeader.IsChecked() != pDlg->GetHeaders() )
862cdf0e10cSrcweir {
863cdf0e10cSrcweir aBtnHeader.Check( pDlg->GetHeaders() );
864cdf0e10cSrcweir }
865cdf0e10cSrcweir
866cdf0e10cSrcweir if ( aBtnTopDown.IsChecked() != pDlg->GetByRows() )
867cdf0e10cSrcweir {
868cdf0e10cSrcweir aBtnTopDown.Check( pDlg->GetByRows() );
869cdf0e10cSrcweir aBtnLeftRight.Check( !pDlg->GetByRows() );
870cdf0e10cSrcweir }
871cdf0e10cSrcweir
872cdf0e10cSrcweir aBtnHeader.SetText( (pDlg->GetByRows())
873cdf0e10cSrcweir ? aStrColLabel
874cdf0e10cSrcweir : aStrRowLabel );
875cdf0e10cSrcweir }
876cdf0e10cSrcweir }
877cdf0e10cSrcweir
878cdf0e10cSrcweir // -----------------------------------------------------------------------
879cdf0e10cSrcweir
DeactivatePage(SfxItemSet * pSetP)880cdf0e10cSrcweir int __EXPORT ScTabPageSortOptions::DeactivatePage( SfxItemSet* pSetP )
881cdf0e10cSrcweir {
882cdf0e10cSrcweir sal_Bool bPosInputOk = sal_True;
883cdf0e10cSrcweir
884cdf0e10cSrcweir if ( aBtnCopyResult.IsChecked() )
885cdf0e10cSrcweir {
886cdf0e10cSrcweir String thePosStr = aEdOutPos.GetText();
887cdf0e10cSrcweir ScAddress thePos;
888cdf0e10cSrcweir xub_StrLen nColonPos = thePosStr.Search( ':' );
889cdf0e10cSrcweir
890cdf0e10cSrcweir if ( STRING_NOTFOUND != nColonPos )
891cdf0e10cSrcweir thePosStr.Erase( nColonPos );
892cdf0e10cSrcweir
893cdf0e10cSrcweir if ( pViewData )
894cdf0e10cSrcweir {
895cdf0e10cSrcweir // visible table is default for input without table
896cdf0e10cSrcweir // must be changed to GetRefTabNo when sorting has RefInput!
897cdf0e10cSrcweir thePos.SetTab( pViewData->GetTabNo() );
898cdf0e10cSrcweir }
899cdf0e10cSrcweir
900cdf0e10cSrcweir sal_uInt16 nResult = thePos.Parse( thePosStr, pDoc, pDoc->GetAddressConvention() );
901cdf0e10cSrcweir
902cdf0e10cSrcweir bPosInputOk = ( SCA_VALID == (nResult & SCA_VALID) );
903cdf0e10cSrcweir
904cdf0e10cSrcweir if ( !bPosInputOk )
905cdf0e10cSrcweir {
906cdf0e10cSrcweir #if !ENABLE_LAYOUT_EXPERIMENTAL
907cdf0e10cSrcweir ErrorBox( this, WinBits( WB_OK | WB_DEF_OK ),
908cdf0e10cSrcweir ScGlobal::GetRscString( STR_INVALID_TABREF )
909cdf0e10cSrcweir ).Execute();
910cdf0e10cSrcweir #endif /* ENABLE_LAYOUT_EXPERIMENTAL */
911cdf0e10cSrcweir aEdOutPos.GrabFocus();
912cdf0e10cSrcweir aEdOutPos.SetSelection( Selection( 0, SELECTION_MAX ) );
913cdf0e10cSrcweir theOutPos.Set(0,0,0);
914cdf0e10cSrcweir }
915cdf0e10cSrcweir else
916cdf0e10cSrcweir {
917cdf0e10cSrcweir aEdOutPos.SetText( thePosStr );
918cdf0e10cSrcweir theOutPos = thePos;
919cdf0e10cSrcweir }
920cdf0e10cSrcweir }
921cdf0e10cSrcweir
922cdf0e10cSrcweir if ( pDlg && bPosInputOk )
923cdf0e10cSrcweir {
924cdf0e10cSrcweir pDlg->SetHeaders( aBtnHeader.IsChecked() );
925cdf0e10cSrcweir pDlg->SetByRows ( aBtnTopDown.IsChecked() );
926cdf0e10cSrcweir }
927cdf0e10cSrcweir
928cdf0e10cSrcweir if ( pSetP && bPosInputOk )
929cdf0e10cSrcweir FillItemSet( *pSetP );
930cdf0e10cSrcweir
931cdf0e10cSrcweir return bPosInputOk ? SfxTabPage::LEAVE_PAGE : SfxTabPage::KEEP_PAGE;
932cdf0e10cSrcweir }
933cdf0e10cSrcweir
934cdf0e10cSrcweir // -----------------------------------------------------------------------
935cdf0e10cSrcweir
FillUserSortListBox()936cdf0e10cSrcweir void ScTabPageSortOptions::FillUserSortListBox()
937cdf0e10cSrcweir {
938cdf0e10cSrcweir ScUserList* pUserLists = ScGlobal::GetUserList();
939cdf0e10cSrcweir
940cdf0e10cSrcweir aLbSortUser.Clear();
941cdf0e10cSrcweir if ( pUserLists )
942cdf0e10cSrcweir {
943cdf0e10cSrcweir sal_uInt16 nCount = pUserLists->GetCount();
944cdf0e10cSrcweir if ( nCount > 0 )
945cdf0e10cSrcweir for ( sal_uInt16 i=0; i<nCount; i++ )
946cdf0e10cSrcweir aLbSortUser.InsertEntry( (*pUserLists)[i]->GetString() );
947cdf0e10cSrcweir }
948cdf0e10cSrcweir }
949cdf0e10cSrcweir
950cdf0e10cSrcweir // -----------------------------------------------------------------------
951cdf0e10cSrcweir // Handler:
952cdf0e10cSrcweir
IMPL_LINK(ScTabPageSortOptions,EnableHdl,CheckBox *,pBox)953cdf0e10cSrcweir IMPL_LINK( ScTabPageSortOptions, EnableHdl, CheckBox *, pBox )
954cdf0e10cSrcweir {
955cdf0e10cSrcweir if ( pBox == &aBtnCopyResult )
956cdf0e10cSrcweir {
957cdf0e10cSrcweir if ( pBox->IsChecked() )
958cdf0e10cSrcweir {
959cdf0e10cSrcweir aLbOutPos.Enable();
960cdf0e10cSrcweir aEdOutPos.Enable();
961cdf0e10cSrcweir aEdOutPos.GrabFocus();
962cdf0e10cSrcweir }
963cdf0e10cSrcweir else
964cdf0e10cSrcweir {
965cdf0e10cSrcweir aLbOutPos.Disable();
966cdf0e10cSrcweir aEdOutPos.Disable();
967cdf0e10cSrcweir }
968cdf0e10cSrcweir }
969cdf0e10cSrcweir else if ( pBox == &aBtnSortUser )
970cdf0e10cSrcweir {
971cdf0e10cSrcweir if ( pBox->IsChecked() )
972cdf0e10cSrcweir {
973cdf0e10cSrcweir aLbSortUser.Enable();
974cdf0e10cSrcweir aLbSortUser.GrabFocus();
975cdf0e10cSrcweir }
976cdf0e10cSrcweir else
977cdf0e10cSrcweir aLbSortUser.Disable();
978cdf0e10cSrcweir }
979cdf0e10cSrcweir return 0;
980cdf0e10cSrcweir }
981cdf0e10cSrcweir
982cdf0e10cSrcweir // -----------------------------------------------------------------------
983cdf0e10cSrcweir
IMPL_LINK(ScTabPageSortOptions,SelOutPosHdl,ListBox *,pLb)984cdf0e10cSrcweir IMPL_LINK( ScTabPageSortOptions, SelOutPosHdl, ListBox *, pLb )
985cdf0e10cSrcweir {
986cdf0e10cSrcweir if ( pLb == &aLbOutPos )
987cdf0e10cSrcweir {
988cdf0e10cSrcweir String aString;
989cdf0e10cSrcweir sal_uInt16 nSelPos = aLbOutPos.GetSelectEntryPos();
990cdf0e10cSrcweir
991cdf0e10cSrcweir if ( nSelPos > 0 )
992cdf0e10cSrcweir aString = *(String*)aLbOutPos.GetEntryData( nSelPos );
993cdf0e10cSrcweir
994cdf0e10cSrcweir aEdOutPos.SetText( aString );
995cdf0e10cSrcweir }
996cdf0e10cSrcweir return 0;
997cdf0e10cSrcweir }
998cdf0e10cSrcweir
999cdf0e10cSrcweir // -----------------------------------------------------------------------
1000cdf0e10cSrcweir
IMPL_LINK(ScTabPageSortOptions,SortDirHdl,RadioButton *,pBtn)1001cdf0e10cSrcweir IMPL_LINK( ScTabPageSortOptions, SortDirHdl, RadioButton *, pBtn )
1002cdf0e10cSrcweir {
1003cdf0e10cSrcweir if ( pBtn == &aBtnTopDown )
1004cdf0e10cSrcweir {
1005cdf0e10cSrcweir aBtnHeader.SetText( aStrColLabel );
1006cdf0e10cSrcweir }
1007cdf0e10cSrcweir else if ( pBtn == &aBtnLeftRight )
1008cdf0e10cSrcweir {
1009cdf0e10cSrcweir aBtnHeader.SetText( aStrRowLabel );
1010cdf0e10cSrcweir }
1011cdf0e10cSrcweir return 0;
1012cdf0e10cSrcweir }
1013cdf0e10cSrcweir
1014cdf0e10cSrcweir // -----------------------------------------------------------------------
1015cdf0e10cSrcweir
EdOutPosModHdl(Edit * pEd)1016cdf0e10cSrcweir void __EXPORT ScTabPageSortOptions::EdOutPosModHdl( Edit* pEd )
1017cdf0e10cSrcweir {
1018cdf0e10cSrcweir if ( pEd == &aEdOutPos )
1019cdf0e10cSrcweir {
1020cdf0e10cSrcweir String theCurPosStr = aEdOutPos.GetText();
1021cdf0e10cSrcweir sal_uInt16 nResult = ScAddress().Parse( theCurPosStr, pDoc, pDoc->GetAddressConvention() );
1022cdf0e10cSrcweir
1023cdf0e10cSrcweir if ( SCA_VALID == (nResult & SCA_VALID) )
1024cdf0e10cSrcweir {
1025cdf0e10cSrcweir String* pStr = NULL;
1026cdf0e10cSrcweir sal_Bool bFound = sal_False;
1027cdf0e10cSrcweir sal_uInt16 i = 0;
1028cdf0e10cSrcweir sal_uInt16 nCount = aLbOutPos.GetEntryCount();
1029cdf0e10cSrcweir
1030cdf0e10cSrcweir for ( i=2; i<nCount && !bFound; i++ )
1031cdf0e10cSrcweir {
1032cdf0e10cSrcweir pStr = (String*)aLbOutPos.GetEntryData( i );
1033cdf0e10cSrcweir bFound = (theCurPosStr == *pStr);
1034cdf0e10cSrcweir }
1035cdf0e10cSrcweir
1036cdf0e10cSrcweir if ( bFound )
1037cdf0e10cSrcweir aLbOutPos.SelectEntryPos( --i );
1038cdf0e10cSrcweir else
1039cdf0e10cSrcweir aLbOutPos.SelectEntryPos( 0 );
1040cdf0e10cSrcweir }
1041cdf0e10cSrcweir }
1042cdf0e10cSrcweir }
1043cdf0e10cSrcweir
1044cdf0e10cSrcweir // -----------------------------------------------------------------------
1045cdf0e10cSrcweir
IMPL_LINK(ScTabPageSortOptions,FillAlgorHdl,void *,EMPTYARG)1046cdf0e10cSrcweir IMPL_LINK( ScTabPageSortOptions, FillAlgorHdl, void *, EMPTYARG )
1047cdf0e10cSrcweir {
1048cdf0e10cSrcweir aLbAlgorithm.SetUpdateMode( sal_False );
1049cdf0e10cSrcweir aLbAlgorithm.Clear();
1050cdf0e10cSrcweir
1051cdf0e10cSrcweir LanguageType eLang = aLbLanguage.GetSelectLanguage();
1052cdf0e10cSrcweir if ( eLang == LANGUAGE_SYSTEM )
1053cdf0e10cSrcweir {
1054cdf0e10cSrcweir // for LANGUAGE_SYSTEM no algorithm can be selected because
1055cdf0e10cSrcweir // it wouldn't necessarily exist for other languages
1056cdf0e10cSrcweir // -> leave list box empty if LANGUAGE_SYSTEM is selected
1057cdf0e10cSrcweir aFtAlgorithm.Enable( sal_False ); // nothing to select
1058cdf0e10cSrcweir aLbAlgorithm.Enable( sal_False ); // nothing to select
1059cdf0e10cSrcweir }
1060cdf0e10cSrcweir else
1061cdf0e10cSrcweir {
1062cdf0e10cSrcweir lang::Locale aLocale( MsLangId::convertLanguageToLocale( eLang ));
1063cdf0e10cSrcweir uno::Sequence<rtl::OUString> aAlgos = pColWrap->listCollatorAlgorithms( aLocale );
1064cdf0e10cSrcweir
1065cdf0e10cSrcweir long nCount = aAlgos.getLength();
1066cdf0e10cSrcweir const rtl::OUString* pArray = aAlgos.getConstArray();
1067cdf0e10cSrcweir for (long i=0; i<nCount; i++)
1068cdf0e10cSrcweir {
1069cdf0e10cSrcweir String sAlg = pArray[i];
1070cdf0e10cSrcweir String sUser = pColRes->GetTranslation( sAlg );
1071cdf0e10cSrcweir aLbAlgorithm.InsertEntry( sUser, LISTBOX_APPEND );
1072cdf0e10cSrcweir }
1073cdf0e10cSrcweir aLbAlgorithm.SelectEntryPos( 0 ); // first entry is default
1074cdf0e10cSrcweir aFtAlgorithm.Enable( nCount > 1 ); // enable only if there is a choice
1075cdf0e10cSrcweir aLbAlgorithm.Enable( nCount > 1 ); // enable only if there is a choice
1076cdf0e10cSrcweir }
1077cdf0e10cSrcweir
1078cdf0e10cSrcweir aLbAlgorithm.SetUpdateMode( sal_True );
1079cdf0e10cSrcweir return 0;
1080cdf0e10cSrcweir }
1081