1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
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/.
9 * This file incorporates work covered by the following license notice:
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 .
20 #include <config_features.h>
22 #include <basic/sberrors.hxx>
23 #include <scitems.hxx>
24 #include <comphelper/lok.hxx>
25 #include <sfx2/viewfrm.hxx>
26 #include <sfx2/request.hxx>
27 #include <basic/sbxcore.hxx>
28 #include <svl/whiter.hxx>
29 #include <svl/numformat.hxx>
30 #include <svl/zforlist.hxx>
31 #include <svl/stritem.hxx>
32 #include <svl/visitem.hxx>
33 #include <unotools/moduleoptions.hxx>
35 #include <com/sun/star/frame/FrameSearchFlag.hpp>
36 #include <com/sun/star/sheet/TableValidationVisibility.hpp>
40 #include <queryparam.hxx>
41 #include <tabvwsh.hxx>
43 #include <globstr.hrc>
44 #include <scresid.hxx>
48 #include <document.hxx>
49 #include <uiitems.hxx>
50 #include <dbdocfun.hxx>
51 #include <reffact.hxx>
52 #include <validat.hxx>
53 #include <validate.hxx>
54 #include <datamapper.hxx>
56 #include <scui_def.hxx>
57 #include <scabstdlg.hxx>
59 #include <asciiopt.hxx>
60 #include <datastream.hxx>
61 #include <datastreamdlg.hxx>
62 #include <dataproviderdlg.hxx>
63 #include <queryentry.hxx>
64 #include <markdata.hxx>
65 #include <documentlinkmgr.hxx>
66 #include <officecfg/Office/Common.hxx>
68 #include <o3tl/make_shared.hxx>
71 using namespace com::sun::star
;
73 static bool lcl_GetTextToColumnsRange( const ScViewData
& rData
, ScRange
& rRange
, bool bDoEmptyCheckOnly
)
76 const ScMarkData
& rMark
= rData
.GetMarkData();
78 if ( rMark
.IsMarked() )
80 if ( !rMark
.IsMultiMarked() )
82 rMark
.GetMarkArea( rRange
);
83 if ( rRange
.aStart
.Col() == rRange
.aEnd
.Col() )
91 const SCCOL nCol
= rData
.GetCurX();
92 const SCROW nRow
= rData
.GetCurY();
93 const SCTAB nTab
= rData
.GetTabNo();
94 rRange
= ScRange( nCol
, nRow
, nTab
, nCol
, nRow
, nTab
);
98 const ScDocument
& rDoc
= rData
.GetDocument();
100 if ( bDoEmptyCheckOnly
)
102 if ( bRet
&& rDoc
.IsBlockEmpty( rRange
.aStart
.Tab(), rRange
.aStart
.Col(),
103 rRange
.aStart
.Row(), rRange
.aEnd
.Col(),
104 rRange
.aEnd
.Row() ) )
112 SCCOL nStartCol
= rRange
.aStart
.Col(), nEndCol
= rRange
.aEnd
.Col();
113 SCROW nStartRow
= rRange
.aStart
.Row(), nEndRow
= rRange
.aEnd
.Row();
114 bool bShrunk
= false;
115 rDoc
.ShrinkToUsedDataArea( bShrunk
, rRange
.aStart
.Tab(), nStartCol
, nStartRow
,
116 nEndCol
, nEndRow
, false, false, true );
119 rRange
.aStart
.SetRow( nStartRow
);
120 rRange
.aEnd
.SetRow( nEndRow
);
127 static bool lcl_GetSortParam( const ScViewData
& rData
, const ScSortParam
& rSortParam
)
129 ScTabViewShell
* pTabViewShell
= rData
.GetViewShell();
130 ScDBData
* pDBData
= pTabViewShell
->GetDBData();
131 ScDocument
& rDoc
= rData
.GetDocument();
132 SCTAB nTab
= rData
.GetTabNo();
133 ScDirection eFillDir
= DIR_TOP
;
135 ScRange aExternalRange
;
137 if( rSortParam
.nCol1
!= rSortParam
.nCol2
)
139 if( rSortParam
.nRow1
!= rSortParam
.nRow2
)
142 if( rSortParam
.nRow2
== rDoc
.MaxRow() )
144 // Assume that user selected entire column(s), but cater for the
145 // possibility that the start row is not the first row.
146 SCSIZE nCount
= rDoc
.GetEmptyLinesInBlock( rSortParam
.nCol1
, rSortParam
.nRow1
, nTab
,
147 rSortParam
.nCol2
, rSortParam
.nRow2
, nTab
, eFillDir
);
148 aExternalRange
= ScRange( rSortParam
.nCol1
,
149 ::std::min( rSortParam
.nRow1
+ sal::static_int_cast
<SCROW
>( nCount
), rDoc
.MaxRow()), nTab
,
150 rSortParam
.nCol2
, rSortParam
.nRow2
, nTab
);
151 aExternalRange
.PutInOrder();
153 else if (rSortParam
.nCol1
!= rSortParam
.nCol2
|| rSortParam
.nRow1
!= rSortParam
.nRow2
)
155 // Preserve a preselected area.
156 aExternalRange
= ScRange( rSortParam
.nCol1
, rSortParam
.nRow1
, nTab
, rSortParam
.nCol2
, rSortParam
.nRow2
, nTab
);
157 aExternalRange
.PutInOrder();
160 aExternalRange
= ScRange( rData
.GetCurX(), rData
.GetCurY(), nTab
);
162 SCROW nStartRow
= aExternalRange
.aStart
.Row();
163 SCCOL nStartCol
= aExternalRange
.aStart
.Col();
164 SCROW nEndRow
= aExternalRange
.aEnd
.Row();
165 SCCOL nEndCol
= aExternalRange
.aEnd
.Col();
166 rDoc
.GetDataArea( aExternalRange
.aStart
.Tab(), nStartCol
, nStartRow
, nEndCol
, nEndRow
, false, false );
167 aExternalRange
.aStart
.SetRow( nStartRow
);
168 aExternalRange
.aStart
.SetCol( nStartCol
);
169 aExternalRange
.aEnd
.SetRow( nEndRow
);
170 aExternalRange
.aEnd
.SetCol( nEndCol
);
172 // with LibreOfficeKit, don't try to interact with the user
173 if (!comphelper::LibreOfficeKit::isActive() &&
174 ((rSortParam
.nCol1
== rSortParam
.nCol2
&& aExternalRange
.aStart
.Col() != aExternalRange
.aEnd
.Col()) ||
175 (rSortParam
.nRow1
== rSortParam
.nRow2
&& aExternalRange
.aStart
.Row() != aExternalRange
.aEnd
.Row())))
177 pTabViewShell
->AddHighlightRange( aExternalRange
,COL_LIGHTBLUE
);
178 OUString
aExtendStr( aExternalRange
.Format(rDoc
, ScRefFlags::VALID
));
180 ScRange
aCurrentRange( rSortParam
.nCol1
, rSortParam
.nRow1
, nTab
, rSortParam
.nCol2
, rSortParam
.nRow2
, nTab
);
181 OUString
aCurrentStr(aCurrentRange
.Format(rDoc
, ScRefFlags::VALID
));
183 ScAbstractDialogFactory
* pFact
= ScAbstractDialogFactory::Create();
185 ScopedVclPtr
<AbstractScSortWarningDlg
> pWarningDlg(pFact
->CreateScSortWarningDlg(pTabViewShell
->GetFrameWeld(), aExtendStr
, aCurrentStr
));
186 short bResult
= pWarningDlg
->Execute();
187 if( bResult
== BTN_EXTEND_RANGE
|| bResult
== BTN_CURRENT_SELECTION
)
189 if( bResult
== BTN_EXTEND_RANGE
)
191 pTabViewShell
->MarkRange( aExternalRange
, false );
192 pDBData
->SetArea( nTab
, aExternalRange
.aStart
.Col(), aExternalRange
.aStart
.Row(), aExternalRange
.aEnd
.Col(), aExternalRange
.aEnd
.Row() );
198 rData
.GetDocShell()->CancelAutoDBRange();
201 pTabViewShell
->ClearHighlightRanges();
208 // this registers the dialog which Find1RefWindow search for
209 class ScValidationRegisteredDlg
211 std::shared_ptr
<SfxDialogController
> m_xDlg
;
213 ScValidationRegisteredDlg(weld::Window
* pParent
, const std::shared_ptr
<SfxDialogController
>& rDlg
)
216 SC_MOD()->RegisterRefController(static_cast<sal_uInt16
>(ScValidationDlg::SLOTID
), m_xDlg
, pParent
);
218 ~ScValidationRegisteredDlg()
221 SC_MOD()->UnregisterRefController(static_cast<sal_uInt16
>(ScValidationDlg::SLOTID
), m_xDlg
);
226 void ScCellShell::ExecuteDB( SfxRequest
& rReq
)
228 ScTabViewShell
* pTabViewShell
= GetViewData().GetViewShell();
229 sal_uInt16 nSlotId
= rReq
.GetSlot();
230 const SfxItemSet
* pReqArgs
= rReq
.GetArgs();
231 ScModule
* pScMod
= SC_MOD();
233 pTabViewShell
->HideListBox(); // Autofilter-DropDown-Listbox
235 if ( GetViewData().HasEditView( GetViewData().GetActivePart() ) )
237 pScMod
->InputEnterHandler();
238 pTabViewShell
->UpdateInputHandler();
243 case SID_VIEW_DATA_SOURCE_BROWSER
:
245 // check if database beamer is open
247 SfxViewFrame
* pViewFrame
= pTabViewShell
->GetViewFrame();
248 bool bWasOpen
= false;
250 uno::Reference
<frame::XFrame
> xFrame
= pViewFrame
->GetFrame().GetFrameInterface();
251 uno::Reference
<frame::XFrame
> xBeamerFrame
= xFrame
->findFrame(
253 frame::FrameSearchFlag::CHILDREN
);
254 if ( xBeamerFrame
.is() )
260 // close database beamer: just forward to SfxViewFrame
262 pViewFrame
->ExecuteSlot( rReq
);
266 // show database beamer: SfxViewFrame call must be synchronous
268 pViewFrame
->ExecuteSlot( rReq
, false ); // false = synchronous
270 // select current database in database beamer
272 ScImportParam aImportParam
;
273 ScDBData
* pDBData
= pTabViewShell
->GetDBData(true,SC_DB_OLD
); // don't create if none found
275 pDBData
->GetImportParam( aImportParam
);
277 ScDBDocFunc::ShowInBeamer( aImportParam
, pTabViewShell
->GetViewFrame() );
279 rReq
.Done(); // needed because it's a toggle slot
283 case SID_REIMPORT_DATA
:
286 ScDBData
* pDBData
= pTabViewShell
->GetDBData(true,SC_DB_OLD
);
289 ScImportParam aImportParam
;
290 pDBData
->GetImportParam( aImportParam
);
291 if (aImportParam
.bImport
&& !pDBData
->HasImportSelection())
293 pTabViewShell
->ImportData( aImportParam
);
294 pDBData
->SetImportParam( aImportParam
); //! Undo ??
299 if (!bOk
&& ! rReq
.IsAPI() )
300 pTabViewShell
->ErrorMessage(STR_REIMPORT_EMPTY
);
307 case SID_REFRESH_DBAREA
:
309 ScDBData
* pDBData
= pTabViewShell
->GetDBData(true,SC_DB_OLD
);
312 // repeat import like SID_REIMPORT_DATA
314 bool bContinue
= true;
315 ScImportParam aImportParam
;
316 pDBData
->GetImportParam( aImportParam
);
317 if (aImportParam
.bImport
&& !pDBData
->HasImportSelection())
319 bContinue
= pTabViewShell
->ImportData( aImportParam
);
320 pDBData
->SetImportParam( aImportParam
); //! Undo ??
322 // mark (size may have been changed)
324 pDBData
->GetArea(aNewRange
);
325 pTabViewShell
->MarkRange(aNewRange
);
328 if ( bContinue
) // fail at import -> break
330 // internal operations, when any stored
332 if ( pDBData
->HasQueryParam() || pDBData
->HasSortParam() ||
333 pDBData
->HasSubTotalParam() )
334 pTabViewShell
->RepeatDB();
336 // pivot tables that have the range as data source
339 pDBData
->GetArea(aRange
);
340 GetViewData().GetDocShell()->RefreshPivotTables(aRange
);
347 case SID_SBA_BRW_INSERT
:
349 OSL_FAIL( "Deprecated Slot" );
355 ScAbstractDialogFactory
* pFact
= ScAbstractDialogFactory::Create();
357 ScopedVclPtr
<AbstractScDataFormDlg
> pDlg(pFact
->CreateScDataFormDlg(
358 pTabViewShell
->GetFrameWeld(), pTabViewShell
));
367 ExecuteSubtotals(rReq
);
370 case SID_SORT_DESCENDING
:
371 case SID_SORT_ASCENDING
:
373 //#i60401 ux-ctest: Calc does not support all users' strategies regarding sorting data
374 //the patch comes from maoyg
375 ScSortParam aSortParam
;
376 ScDBData
* pDBData
= pTabViewShell
->GetDBData();
377 ScViewData
& rData
= GetViewData();
379 pDBData
->GetSortParam( aSortParam
);
381 if( lcl_GetSortParam( rData
, aSortParam
) )
383 SCCOL nCol
= GetViewData().GetCurX();
384 SCCOL nTab
= GetViewData().GetTabNo();
385 ScDocument
& rDoc
= GetViewData().GetDocument();
387 pDBData
->GetSortParam( aSortParam
);
388 bool bHasHeader
= rDoc
.HasColHeader( aSortParam
.nCol1
, aSortParam
.nRow1
, aSortParam
.nCol2
, aSortParam
.nRow2
, nTab
);
390 if( nCol
< aSortParam
.nCol1
)
391 nCol
= aSortParam
.nCol1
;
392 else if( nCol
> aSortParam
.nCol2
)
393 nCol
= aSortParam
.nCol2
;
395 aSortParam
.bHasHeader
= bHasHeader
;
396 aSortParam
.bByRow
= true;
397 aSortParam
.bCaseSens
= false;
398 aSortParam
.bNaturalSort
= false;
399 aSortParam
.aDataAreaExtras
.mbCellNotes
= false;
400 aSortParam
.aDataAreaExtras
.mbCellDrawObjects
= true;
401 aSortParam
.aDataAreaExtras
.mbCellFormats
= true;
402 aSortParam
.bInplace
= true;
403 aSortParam
.maKeyState
[0].bDoSort
= true;
404 aSortParam
.maKeyState
[0].nField
= nCol
;
405 aSortParam
.maKeyState
[0].bAscending
= ( nSlotId
== SID_SORT_ASCENDING
);
407 for ( sal_uInt16 i
=1; i
<aSortParam
.GetSortKeyCount(); i
++ )
408 aSortParam
.maKeyState
[i
].bDoSort
= false;
410 pTabViewShell
->UISort( aSortParam
); // subtotal when needed new
419 const SfxItemSet
* pArgs
= rReq
.GetArgs();
421 //#i60401 ux-ctest: Calc does not support all users' strategies regarding sorting data
422 //the patch comes from maoyg
424 if ( pArgs
) // Basic
426 ScSortParam aSortParam
;
427 ScDBData
* pDBData
= pTabViewShell
->GetDBData();
428 ScViewData
& rData
= GetViewData();
430 pDBData
->GetSortParam( aSortParam
);
432 if( lcl_GetSortParam( rData
, aSortParam
) )
434 ScDocument
& rDoc
= GetViewData().GetDocument();
436 pDBData
->GetSortParam( aSortParam
);
437 bool bHasHeader
= rDoc
.HasColHeader( aSortParam
.nCol1
, aSortParam
.nRow1
, aSortParam
.nCol2
, aSortParam
.nRow2
, rData
.GetTabNo() );
439 aSortParam
.bHasHeader
= bHasHeader
;
441 aSortParam
.bInplace
= true; // from Basic always
443 const SfxPoolItem
* pItem
;
444 if ( pArgs
->GetItemState( SID_SORT_BYROW
, true, &pItem
) == SfxItemState::SET
)
445 aSortParam
.bByRow
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
446 if ( pArgs
->GetItemState( SID_SORT_HASHEADER
, true, &pItem
) == SfxItemState::SET
)
447 aSortParam
.bHasHeader
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
448 if ( pArgs
->GetItemState( SID_SORT_CASESENS
, true, &pItem
) == SfxItemState::SET
)
449 aSortParam
.bCaseSens
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
450 if ( pArgs
->GetItemState( SID_SORT_NATURALSORT
, true, &pItem
) == SfxItemState::SET
)
451 aSortParam
.bNaturalSort
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
452 if ( pArgs
->GetItemState( SID_SORT_INCCOMMENTS
, true, &pItem
) == SfxItemState::SET
)
453 aSortParam
.aDataAreaExtras
.mbCellNotes
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
454 if ( pArgs
->GetItemState( SID_SORT_INCIMAGES
, true, &pItem
) == SfxItemState::SET
)
455 aSortParam
.aDataAreaExtras
.mbCellDrawObjects
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
456 if ( pArgs
->GetItemState( SID_SORT_ATTRIBS
, true, &pItem
) == SfxItemState::SET
)
457 aSortParam
.aDataAreaExtras
.mbCellFormats
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
458 if ( pArgs
->GetItemState( SID_SORT_USERDEF
, true, &pItem
) == SfxItemState::SET
)
460 sal_uInt16 nUserIndex
= static_cast<const SfxUInt16Item
*>(pItem
)->GetValue();
461 aSortParam
.bUserDef
= ( nUserIndex
!= 0 );
463 aSortParam
.nUserIndex
= nUserIndex
- 1; // Basic: 1-based
466 SCCOLROW nField0
= 0;
467 if ( pArgs
->GetItemState( FN_PARAM_1
, true, &pItem
) == SfxItemState::SET
)
468 nField0
= static_cast<const SfxInt32Item
*>(pItem
)->GetValue();
469 aSortParam
.maKeyState
[0].bDoSort
= ( nField0
!= 0 );
470 aSortParam
.maKeyState
[0].nField
= nField0
> 0 ? (nField0
-1) : 0;
471 if ( pArgs
->GetItemState( FN_PARAM_2
, true, &pItem
) == SfxItemState::SET
)
472 aSortParam
.maKeyState
[0].bAscending
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
473 SCCOLROW nField1
= 0;
474 if ( pArgs
->GetItemState( FN_PARAM_3
, true, &pItem
) == SfxItemState::SET
)
475 nField1
= static_cast<const SfxInt32Item
*>(pItem
)->GetValue();
476 aSortParam
.maKeyState
[1].bDoSort
= ( nField1
!= 0 );
477 aSortParam
.maKeyState
[1].nField
= nField1
> 0 ? (nField1
-1) : 0;
478 if ( pArgs
->GetItemState( FN_PARAM_4
, true, &pItem
) == SfxItemState::SET
)
479 aSortParam
.maKeyState
[1].bAscending
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
480 SCCOLROW nField2
= 0;
481 if ( pArgs
->GetItemState( FN_PARAM_5
, true, &pItem
) == SfxItemState::SET
)
482 nField2
= static_cast<const SfxInt32Item
*>(pItem
)->GetValue();
483 aSortParam
.maKeyState
[2].bDoSort
= ( nField2
!= 0 );
484 aSortParam
.maKeyState
[2].nField
= nField2
> 0 ? (nField2
-1) : 0;
485 if ( pArgs
->GetItemState( FN_PARAM_6
, true, &pItem
) == SfxItemState::SET
)
486 aSortParam
.maKeyState
[2].bAscending
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
488 // subtotal when needed new
489 pTabViewShell
->UISort( aSortParam
);
495 ScSortParam aSortParam
;
496 ScDBData
* pDBData
= pTabViewShell
->GetDBData();
497 ScViewData
& rData
= GetViewData();
499 pDBData
->GetSortParam( aSortParam
);
501 if( lcl_GetSortParam( rData
, aSortParam
) )
503 ScDocument
& rDoc
= GetViewData().GetDocument();
504 SfxItemSetFixed
<SCITEM_SORTDATA
, SCITEM_SORTDATA
> aArgSet( GetPool() );
506 pDBData
->GetSortParam( aSortParam
);
507 bool bHasHeader
= rDoc
.HasColHeader( aSortParam
.nCol1
, aSortParam
.nRow1
, aSortParam
.nCol2
, aSortParam
.nRow2
, rData
.GetTabNo() );
509 aSortParam
.bHasHeader
= bHasHeader
;
511 aArgSet
.Put( ScSortItem( SCITEM_SORTDATA
, &GetViewData(), &aSortParam
) );
513 ScAbstractDialogFactory
* pFact
= ScAbstractDialogFactory::Create();
514 std::shared_ptr
<ScAsyncTabController
> pDlg(pFact
->CreateScSortDlg(pTabViewShell
->GetFrameWeld(), &aArgSet
));
515 pDlg
->SetCurPageId("criteria"); // 1=sort field tab 2=sort options tab
517 VclAbstractDialog::AsyncContext aContext
;
518 aContext
.maEndDialogFn
= [pDlg
, &rData
, pTabViewShell
](sal_Int32 nResult
)
520 if ( nResult
== RET_OK
)
522 const SfxItemSet
* pOutSet
= pDlg
->GetOutputItemSet();
523 const ScSortParam
& rOutParam
= static_cast<const ScSortItem
&>(
524 pOutSet
->Get( SCITEM_SORTDATA
)).GetSortData();
526 // subtotal when needed new
528 pTabViewShell
->UISort( rOutParam
);
530 SfxViewFrame
* pViewFrm
= pTabViewShell
->GetViewFrame();
533 SfxRequest
aRequest(pViewFrm
, SID_SORT
);
535 if ( rOutParam
.bInplace
)
537 aRequest
.AppendItem( SfxBoolItem( SID_SORT_BYROW
,
538 rOutParam
.bByRow
) );
539 aRequest
.AppendItem( SfxBoolItem( SID_SORT_HASHEADER
,
540 rOutParam
.bHasHeader
) );
541 aRequest
.AppendItem( SfxBoolItem( SID_SORT_CASESENS
,
542 rOutParam
.bCaseSens
) );
543 aRequest
.AppendItem( SfxBoolItem( SID_SORT_NATURALSORT
,
544 rOutParam
.bNaturalSort
) );
545 aRequest
.AppendItem( SfxBoolItem( SID_SORT_INCCOMMENTS
,
546 rOutParam
.aDataAreaExtras
.mbCellNotes
) );
547 aRequest
.AppendItem( SfxBoolItem( SID_SORT_INCIMAGES
,
548 rOutParam
.aDataAreaExtras
.mbCellDrawObjects
) );
549 aRequest
.AppendItem( SfxBoolItem( SID_SORT_ATTRIBS
,
550 rOutParam
.aDataAreaExtras
.mbCellFormats
) );
551 sal_uInt16 nUser
= rOutParam
.bUserDef
? ( rOutParam
.nUserIndex
+ 1 ) : 0;
552 aRequest
.AppendItem( SfxUInt16Item( SID_SORT_USERDEF
, nUser
) );
553 if ( rOutParam
.maKeyState
[0].bDoSort
)
555 aRequest
.AppendItem( SfxInt32Item( FN_PARAM_1
,
556 rOutParam
.maKeyState
[0].nField
+ 1 ) );
557 aRequest
.AppendItem( SfxBoolItem( FN_PARAM_2
,
558 rOutParam
.maKeyState
[0].bAscending
) );
560 if ( rOutParam
.maKeyState
[1].bDoSort
)
562 aRequest
.AppendItem( SfxInt32Item( FN_PARAM_3
,
563 rOutParam
.maKeyState
[1].nField
+ 1 ) );
564 aRequest
.AppendItem( SfxBoolItem( FN_PARAM_4
,
565 rOutParam
.maKeyState
[1].bAscending
) );
567 if ( rOutParam
.maKeyState
[2].bDoSort
)
569 aRequest
.AppendItem( SfxInt32Item( FN_PARAM_5
,
570 rOutParam
.maKeyState
[2].nField
+ 1 ) );
571 aRequest
.AppendItem( SfxBoolItem( FN_PARAM_6
,
572 rOutParam
.maKeyState
[2].bAscending
) );
581 rData
.GetDocShell()->CancelAutoDBRange();
585 pDlg
->StartExecuteAsync(aContext
);
593 const SfxItemSet
* pArgs
= rReq
.GetArgs();
596 OSL_FAIL("SID_FILTER with arguments?");
597 pTabViewShell
->Query( static_cast<const ScQueryItem
&>(
598 pArgs
->Get( SCITEM_QUERYDATA
)).GetQueryData(), nullptr, true );
603 sal_uInt16 nId
= ScFilterDlgWrapper::GetChildWindowId();
604 SfxViewFrame
* pViewFrm
= pTabViewShell
->GetViewFrame();
605 SfxChildWindow
* pWnd
= pViewFrm
->GetChildWindow( nId
);
607 pScMod
->SetRefDialog( nId
, pWnd
== nullptr );
612 case SID_SPECIAL_FILTER
:
614 const SfxItemSet
* pArgs
= rReq
.GetArgs();
617 OSL_FAIL("SID_SPECIAL_FILTER with arguments?");
618 pTabViewShell
->Query( static_cast<const ScQueryItem
&>(
619 pArgs
->Get( SCITEM_QUERYDATA
)).GetQueryData(), nullptr, true );
624 sal_uInt16 nId
= ScSpecialFilterDlgWrapper::GetChildWindowId();
625 SfxViewFrame
* pViewFrm
= pTabViewShell
->GetViewFrame();
626 SfxChildWindow
* pWnd
= pViewFrm
->GetChildWindow( nId
);
628 pScMod
->SetRefDialog( nId
, pWnd
== nullptr );
635 const SfxPoolItem
* pItem
;
636 if ( pReqArgs
&& SfxItemState::SET
==
637 pReqArgs
->GetItemState( SCITEM_QUERYDATA
, true, &pItem
) )
639 const ScQueryItem
& rQueryItem
= static_cast<const ScQueryItem
&>(*pItem
);
641 SCTAB nCurTab
= GetViewData().GetTabNo();
642 SCTAB nRefTab
= GetViewData().GetRefTabNo();
644 // If RefInput switched to a different sheet from the data sheet,
647 if ( nCurTab
!= nRefTab
)
649 pTabViewShell
->SetTabNo( nRefTab
);
650 pTabViewShell
->PaintExtras();
654 if (rQueryItem
.GetAdvancedQuerySource(aAdvSource
))
655 pTabViewShell
->Query( rQueryItem
.GetQueryData(), &aAdvSource
, true );
657 pTabViewShell
->Query( rQueryItem
.GetQueryData(), nullptr, true );
658 rReq
.Done( *pReqArgs
);
666 ScDBData
* pDBData
= pTabViewShell
->GetDBData();
668 pDBData
->GetQueryParam( aParam
);
669 SCSIZE nEC
= aParam
.GetEntryCount();
670 for (SCSIZE i
=0; i
<nEC
; i
++)
671 aParam
.GetEntry(i
).bDoQuery
= false;
672 aParam
.bDuplicate
= true;
673 pTabViewShell
->Query( aParam
, nullptr, true );
678 case SID_AUTO_FILTER
:
679 pTabViewShell
->ToggleAutoFilter();
683 case SID_AUTOFILTER_HIDE
:
684 pTabViewShell
->HideAutoFilter();
688 case SID_PIVOT_TABLE
:
690 const SfxPoolItem
* pItem
;
691 if ( pReqArgs
&& SfxItemState::SET
==
692 pReqArgs
->GetItemState( SCITEM_PIVOTDATA
, true, &pItem
) )
694 SCTAB nCurTab
= GetViewData().GetTabNo();
695 SCTAB nRefTab
= GetViewData().GetRefTabNo();
697 // If RefInput switched to a different sheet from the data sheet,
700 if ( nCurTab
!= nRefTab
)
702 pTabViewShell
->SetTabNo( nRefTab
);
703 pTabViewShell
->PaintExtras();
706 const ScDPObject
* pDPObject
= pTabViewShell
->GetDialogDPObject();
709 const ScPivotItem
* pPItem
= static_cast<const ScPivotItem
*>(pItem
);
710 bool bSuccess
= pTabViewShell
->MakePivotTable(
711 pPItem
->GetData(), pPItem
->GetDestRange(), pPItem
->IsNewSheet(), *pDPObject
);
712 SfxBoolItem
aRet(0, bSuccess
);
713 rReq
.SetReturnValue(aRet
);
717 #if HAVE_FEATURE_SCRIPTING
718 else if (rReq
.IsAPI())
719 SbxBase::SetError(ERRCODE_BASIC_BAD_PARAMETER
);
724 case SID_OPENDLG_PIVOTTABLE
:
725 ExecuteDataPilotDialog();
727 case SID_DEFINE_DBNAME
:
730 sal_uInt16 nId
= ScDbNameDlgWrapper::GetChildWindowId();
731 SfxViewFrame
* pViewFrm
= pTabViewShell
->GetViewFrame();
732 SfxChildWindow
* pWnd
= pViewFrm
->GetChildWindow( nId
);
734 pScMod
->SetRefDialog( nId
, pWnd
== nullptr );
743 const SfxStringItem
& rItem
744 = static_cast<const SfxStringItem
&>(pReqArgs
->Get(SID_SELECT_DB
));
745 pTabViewShell
->GotoDBArea(rItem
.GetValue());
750 ScDocument
& rDoc
= GetViewData().GetDocument();
751 ScDBCollection
* pDBCol
= rDoc
.GetDBCollection();
755 std::vector
<OUString
> aList
;
756 const ScDBCollection::NamedDBs
& rDBs
= pDBCol
->getNamedDBs();
757 for (const auto& rxDB
: rDBs
)
758 aList
.push_back(rxDB
->GetName());
760 ScAbstractDialogFactory
* pFact
= ScAbstractDialogFactory::Create();
762 ScopedVclPtr
<AbstractScSelEntryDlg
> pDlg(pFact
->CreateScSelEntryDlg(pTabViewShell
->GetFrameWeld(), aList
));
763 if ( pDlg
->Execute() == RET_OK
)
765 OUString aName
= pDlg
->GetSelectedEntry();
766 pTabViewShell
->GotoDBArea( aName
);
767 rReq
.AppendItem( SfxStringItem( SID_SELECT_DB
, aName
) );
774 case SID_DATA_STREAMS
:
776 sc::DataStreamDlg
aDialog(GetViewData().GetDocShell(), pTabViewShell
->GetFrameWeld());
777 ScDocument
& rDoc
= GetViewData().GetDocument();
778 sc::DocumentLinkManager
& rMgr
= rDoc
.GetDocLinkManager();
779 sc::DataStream
* pStrm
= rMgr
.getDataStream();
781 aDialog
.Init(*pStrm
);
783 if (aDialog
.run() == RET_OK
)
784 aDialog
.StartStream();
787 case SID_DATA_STREAMS_PLAY
:
789 ScDocument
& rDoc
= GetViewData().GetDocument();
790 sc::DocumentLinkManager
& rMgr
= rDoc
.GetDocLinkManager();
791 sc::DataStream
* pStrm
= rMgr
.getDataStream();
793 pStrm
->StartImport();
796 case SID_DATA_STREAMS_STOP
:
798 ScDocument
& rDoc
= GetViewData().GetDocument();
799 sc::DocumentLinkManager
& rMgr
= rDoc
.GetDocLinkManager();
800 sc::DataStream
* pStrm
= rMgr
.getDataStream();
805 case SID_DATA_PROVIDER
:
807 auto xDoc
= o3tl::make_shared
<ScDocument
>();
808 xDoc
->InsertTab(0, "test");
809 ScDocument
& rDoc
= GetViewData().GetDocument();
810 ScDataProviderDlg
aDialog(pTabViewShell
->GetDialogParent(), xDoc
, &rDoc
);
811 if (aDialog
.run() == RET_OK
)
813 aDialog
.import(rDoc
);
817 case SID_DATA_PROVIDER_REFRESH
:
819 ScDocument
& rDoc
= GetViewData().GetDocument();
820 auto& rDataMapper
= rDoc
.GetExternalDataMapper();
821 for (auto& rDataSource
: rDataMapper
.getDataSources())
823 rDataSource
.refresh(&rDoc
, false);
827 case SID_MANAGE_XML_SOURCE
:
828 ExecuteXMLSourceDialog();
831 case FID_CURRENTVALIDATION
:
833 const SfxPoolItem
* pItem
;
834 const SfxItemSet
* pArgs
= rReq
.GetArgs();
837 OSL_FAIL("later...");
841 SfxItemSet
aArgSet( GetPool(), ScTPValidationValue::GetRanges() );
842 ScValidationMode eMode
= SC_VALID_ANY
;
843 ScConditionMode eOper
= ScConditionMode::Equal
;
844 OUString aExpr1
, aExpr2
;
846 sal_Int16 nListType
= css::sheet::TableValidationVisibility::UNSORTED
;
847 bool bShowHelp
= false;
848 OUString aHelpTitle
, aHelpText
;
849 bool bShowError
= false;
850 ScValidErrorStyle eErrStyle
= SC_VALERR_STOP
;
851 OUString aErrTitle
, aErrText
;
853 ScDocument
& rDoc
= GetViewData().GetDocument();
854 SCCOL nCurX
= GetViewData().GetCurX();
855 SCROW nCurY
= GetViewData().GetCurY();
856 SCTAB nTab
= GetViewData().GetTabNo();
857 ScAddress
aCursorPos( nCurX
, nCurY
, nTab
);
858 sal_uLong nIndex
= rDoc
.GetAttr(
859 nCurX
, nCurY
, nTab
, ATTR_VALIDDATA
)->GetValue();
862 const ScValidationData
* pOldData
= rDoc
.GetValidationEntry( nIndex
);
865 eMode
= pOldData
->GetDataMode();
866 eOper
= pOldData
->GetOperation();
867 sal_uInt32 nNumFmt
= 0;
868 if ( eMode
== SC_VALID_DATE
|| eMode
== SC_VALID_TIME
)
870 SvNumFormatType nType
= ( eMode
== SC_VALID_DATE
) ? SvNumFormatType::DATE
871 : SvNumFormatType::TIME
;
872 nNumFmt
= rDoc
.GetFormatTable()->GetStandardFormat(
873 nType
, ScGlobal::eLnge
);
875 aExpr1
= pOldData
->GetExpression( aCursorPos
, 0, nNumFmt
);
876 aExpr2
= pOldData
->GetExpression( aCursorPos
, 1, nNumFmt
);
877 bBlank
= pOldData
->IsIgnoreBlank();
878 nListType
= pOldData
->GetListType();
880 bShowHelp
= pOldData
->GetInput( aHelpTitle
, aHelpText
);
881 bShowError
= pOldData
->GetErrMsg( aErrTitle
, aErrText
, eErrStyle
);
883 aArgSet
.Put( SfxUInt16Item( FID_VALID_MODE
, sal::static_int_cast
<sal_uInt16
>(eMode
) ) );
884 aArgSet
.Put( SfxUInt16Item( FID_VALID_CONDMODE
, sal::static_int_cast
<sal_uInt16
>(eOper
) ) );
885 aArgSet
.Put( SfxStringItem( FID_VALID_VALUE1
, aExpr1
) );
886 aArgSet
.Put( SfxStringItem( FID_VALID_VALUE2
, aExpr2
) );
887 aArgSet
.Put( SfxBoolItem( FID_VALID_BLANK
, bBlank
) );
888 aArgSet
.Put( SfxInt16Item( FID_VALID_LISTTYPE
, nListType
) );
889 aArgSet
.Put( SfxBoolItem( FID_VALID_SHOWHELP
, bShowHelp
) );
890 aArgSet
.Put( SfxStringItem( FID_VALID_HELPTITLE
, aHelpTitle
) );
891 aArgSet
.Put( SfxStringItem( FID_VALID_HELPTEXT
, aHelpText
) );
892 aArgSet
.Put( SfxBoolItem( FID_VALID_SHOWERR
, bShowError
) );
893 aArgSet
.Put( SfxUInt16Item( FID_VALID_ERRSTYLE
, sal::static_int_cast
<sal_uInt16
>(eErrStyle
) ) );
894 aArgSet
.Put( SfxStringItem( FID_VALID_ERRTITLE
, aErrTitle
) );
895 aArgSet
.Put( SfxStringItem( FID_VALID_ERRTEXT
, aErrText
) );
900 vcl::Window
* pWin
= GetViewData().GetActiveWin();
901 weld::Window
* pParentWin
= pWin
? pWin
->GetFrameWeld() : nullptr;
902 auto xDlg
= std::make_shared
<ScValidationDlg
>(pParentWin
, &aArgSet
, pTabViewShell
);
903 ScValidationRegisteredDlg
aRegisterThatDlgExists(pParentWin
, xDlg
);
905 short nResult
= xDlg
->run();
906 if ( nResult
== RET_OK
)
908 const SfxItemSet
* pOutSet
= xDlg
->GetOutputItemSet();
910 if ( pOutSet
->GetItemState( FID_VALID_MODE
, true, &pItem
) == SfxItemState::SET
)
911 eMode
= static_cast<ScValidationMode
>(static_cast<const SfxUInt16Item
*>(pItem
)->GetValue());
912 if ( pOutSet
->GetItemState( FID_VALID_CONDMODE
, true, &pItem
) == SfxItemState::SET
)
913 eOper
= static_cast<ScConditionMode
>(static_cast<const SfxUInt16Item
*>(pItem
)->GetValue());
914 if ( pOutSet
->GetItemState( FID_VALID_VALUE1
, true, &pItem
) == SfxItemState::SET
)
916 OUString aTemp1
= static_cast<const SfxStringItem
*>(pItem
)->GetValue();
917 if (eMode
== SC_VALID_DATE
|| eMode
== SC_VALID_TIME
)
919 sal_uInt32 nNumIndex
= 0;
921 if (rDoc
.GetFormatTable()->IsNumberFormat(aTemp1
, nNumIndex
, nVal
))
922 aExpr1
= ::rtl::math::doubleToUString( nVal
,
923 rtl_math_StringFormat_Automatic
, rtl_math_DecimalPlaces_Max
,
924 ScGlobal::getLocaleData().getNumDecimalSep()[0], true);
931 if ( pOutSet
->GetItemState( FID_VALID_VALUE2
, true, &pItem
) == SfxItemState::SET
)
933 OUString aTemp2
= static_cast<const SfxStringItem
*>(pItem
)->GetValue();
934 if (eMode
== SC_VALID_DATE
|| eMode
== SC_VALID_TIME
)
936 sal_uInt32 nNumIndex
= 0;
938 if (rDoc
.GetFormatTable()->IsNumberFormat(aTemp2
, nNumIndex
, nVal
))
939 aExpr2
= ::rtl::math::doubleToUString( nVal
,
940 rtl_math_StringFormat_Automatic
, rtl_math_DecimalPlaces_Max
,
941 ScGlobal::getLocaleData().getNumDecimalSep()[0], true);
944 if ( eMode
== SC_VALID_TIME
) {
945 sal_Int32 wraparound
= aExpr1
.compareTo(aExpr2
);
946 if (wraparound
> 0) {
947 if (eOper
== ScConditionMode::Between
) {
948 eOper
= ScConditionMode::NotBetween
;
949 OUString tmp
= aExpr1
;
953 else if (eOper
== ScConditionMode::NotBetween
) {
954 eOper
= ScConditionMode::Between
;
955 OUString tmp
= aExpr1
;
965 if ( pOutSet
->GetItemState( FID_VALID_BLANK
, true, &pItem
) == SfxItemState::SET
)
966 bBlank
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
967 if ( pOutSet
->GetItemState( FID_VALID_LISTTYPE
, true, &pItem
) == SfxItemState::SET
)
968 nListType
= static_cast<const SfxInt16Item
*>(pItem
)->GetValue();
970 if ( pOutSet
->GetItemState( FID_VALID_SHOWHELP
, true, &pItem
) == SfxItemState::SET
)
971 bShowHelp
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
972 if ( pOutSet
->GetItemState( FID_VALID_HELPTITLE
, true, &pItem
) == SfxItemState::SET
)
973 aHelpTitle
= static_cast<const SfxStringItem
*>(pItem
)->GetValue();
974 if ( pOutSet
->GetItemState( FID_VALID_HELPTEXT
, true, &pItem
) == SfxItemState::SET
)
975 aHelpText
= static_cast<const SfxStringItem
*>(pItem
)->GetValue();
977 if ( pOutSet
->GetItemState( FID_VALID_SHOWERR
, true, &pItem
) == SfxItemState::SET
)
978 bShowError
= static_cast<const SfxBoolItem
*>(pItem
)->GetValue();
979 if ( pOutSet
->GetItemState( FID_VALID_ERRSTYLE
, true, &pItem
) == SfxItemState::SET
)
980 eErrStyle
= static_cast<ScValidErrorStyle
>(static_cast<const SfxUInt16Item
*>(pItem
)->GetValue());
981 if ( pOutSet
->GetItemState( FID_VALID_ERRTITLE
, true, &pItem
) == SfxItemState::SET
)
982 aErrTitle
= static_cast<const SfxStringItem
*>(pItem
)->GetValue();
983 if ( pOutSet
->GetItemState( FID_VALID_ERRTEXT
, true, &pItem
) == SfxItemState::SET
)
984 aErrText
= static_cast<const SfxStringItem
*>(pItem
)->GetValue();
986 ScValidationData
aData( eMode
, eOper
, aExpr1
, aExpr2
, rDoc
, aCursorPos
);
987 aData
.SetIgnoreBlank( bBlank
);
988 aData
.SetListType( nListType
);
990 aData
.SetInput(aHelpTitle
, aHelpText
); // sets bShowInput to TRUE
992 aData
.ResetInput(); // reset only bShowInput
994 aData
.SetError(aErrTitle
, aErrText
, eErrStyle
); // sets bShowError to TRUE
996 aData
.ResetError(); // reset only bShowError
998 pTabViewShell
->SetValidation( aData
);
999 pTabViewShell
->TestHintWindow();
1000 rReq
.Done( *pOutSet
);
1006 case SID_TEXT_TO_COLUMNS
:
1008 ScViewData
& rData
= GetViewData();
1011 if ( lcl_GetTextToColumnsRange( rData
, aRange
, false ) )
1013 ScDocument
& rDoc
= rData
.GetDocument();
1015 ScImportExport
aExport( rDoc
, aRange
);
1016 aExport
.SetExportTextOptions( ScExportTextOptions( ScExportTextOptions::None
, 0, false ) );
1018 // #i87703# text to columns fails with tab separator
1019 aExport
.SetDelimiter( u
'\0' );
1021 SvMemoryStream aStream
;
1022 aStream
.SetStreamCharSet( RTL_TEXTENCODING_UNICODE
);
1023 ScImportExport::SetNoEndianSwap( aStream
);
1024 aExport
.ExportStream( aStream
, OUString(), SotClipboardFormatId::STRING
);
1026 ScAbstractDialogFactory
* pFact
= ScAbstractDialogFactory::Create();
1027 ScopedVclPtr
<AbstractScImportAsciiDlg
> pDlg(pFact
->CreateScImportAsciiDlg(
1028 pTabViewShell
->GetFrameWeld(), OUString(), &aStream
, SC_TEXTTOCOLUMNS
));
1030 if ( pDlg
->Execute() == RET_OK
)
1032 ScDocShell
* pDocSh
= rData
.GetDocShell();
1033 OSL_ENSURE( pDocSh
, "ScCellShell::ExecuteDB: SID_TEXT_TO_COLUMNS - pDocSh is null!" );
1035 OUString aUndo
= ScResId( STR_UNDO_TEXTTOCOLUMNS
);
1036 pDocSh
->GetUndoManager()->EnterListAction( aUndo
, aUndo
, 0, rData
.GetViewShell()->GetViewShellId() );
1038 ScImportExport
aImport( rDoc
, aRange
.aStart
);
1039 ScAsciiOptions aOptions
;
1040 pDlg
->GetOptions( aOptions
);
1041 pDlg
->SaveParameters();
1042 aImport
.SetExtOptions( aOptions
);
1043 aImport
.SetApi( false );
1044 aImport
.SetImportBroadcast( true );
1045 aImport
.SetOverwriting( true );
1047 aImport
.ImportStream( aStream
, OUString(), SotClipboardFormatId::STRING
);
1049 pDocSh
->GetUndoManager()->LeaveListAction();
1057 void ScCellShell::GetDBState( SfxItemSet
& rSet
)
1059 ScTabViewShell
* pTabViewShell
= GetViewData().GetViewShell();
1060 ScViewData
& rData
= GetViewData();
1061 ScDocShell
* pDocSh
= rData
.GetDocShell();
1062 ScDocument
& rDoc
= pDocSh
->GetDocument();
1063 SCCOL nPosX
= rData
.GetCurX();
1064 SCROW nPosY
= rData
.GetCurY();
1065 SCTAB nTab
= rData
.GetTabNo();
1067 bool bAutoFilter
= false;
1068 bool bAutoFilterTested
= false;
1070 SfxWhichIter
aIter(rSet
);
1071 sal_uInt16 nWhich
= aIter
.FirstWhich();
1076 case SID_REFRESH_DBAREA
:
1078 // imported data without selection
1079 // or filter,sort,subtotal (also without import)
1081 ScDBData
* pDBData
= pTabViewShell
->GetDBData(false,SC_DB_OLD
);
1082 if (pDBData
&& rDoc
.GetChangeTrack() == nullptr)
1084 if ( pDBData
->HasImportParam() )
1085 bOk
= !pDBData
->HasImportSelection();
1088 bOk
= pDBData
->HasQueryParam() ||
1089 pDBData
->HasSortParam() ||
1090 pDBData
->HasSubTotalParam();
1094 rSet
.DisableItem( nWhich
);
1099 case SID_SPECIAL_FILTER
:
1102 ScMarkType eMarkType
= GetViewData().GetSimpleArea( aDummy
);
1103 if (eMarkType
!= SC_MARK_SIMPLE
&& eMarkType
!= SC_MARK_SIMPLE_FILTERED
)
1105 rSet
.DisableItem( nWhich
);
1110 //in case of Redlining and multiselection disable
1111 case SID_SORT_ASCENDING
:
1112 case SID_SORT_DESCENDING
:
1113 case SCITEM_SORTDATA
:
1114 case SCITEM_SUBTDATA
:
1115 case SID_OPENDLG_PIVOTTABLE
:
1117 //! move ReadOnly check to idl flags
1119 if ( pDocSh
->IsReadOnly() || rDoc
.GetChangeTrack()!=nullptr ||
1120 GetViewData().IsMultiMarked() )
1122 rSet
.DisableItem( nWhich
);
1127 case SID_REIMPORT_DATA
:
1129 // only imported data without selection
1130 ScDBData
* pDBData
= pTabViewShell
->GetDBData(false,SC_DB_OLD
);
1131 if (!pDBData
|| !pDBData
->HasImportParam() || pDBData
->HasImportSelection() ||
1132 rDoc
.GetChangeTrack()!=nullptr)
1134 rSet
.DisableItem( nWhich
);
1139 case SID_VIEW_DATA_SOURCE_BROWSER
:
1141 if (!SvtModuleOptions().IsModuleInstalled(SvtModuleOptions::EModule::DATABASE
))
1142 rSet
.Put(SfxVisibilityItem(nWhich
, false));
1144 // get state (BoolItem) from SfxViewFrame
1145 pTabViewShell
->GetViewFrame()->GetSlotState( nWhich
, nullptr, &rSet
);
1148 case SID_SBA_BRW_INSERT
:
1150 // SBA wants a sal_Bool-item, enabled
1152 rSet
.Put(SfxBoolItem(nWhich
, true));
1156 case SID_AUTO_FILTER
:
1157 case SID_AUTOFILTER_HIDE
:
1159 if (!bAutoFilterTested
)
1161 bAutoFilter
= rDoc
.HasAutoFilter( nPosX
, nPosY
, nTab
);
1162 bAutoFilterTested
= true;
1164 if ( nWhich
== SID_AUTO_FILTER
)
1167 ScMarkType eMarkType
= GetViewData().GetSimpleArea( aDummy
);
1168 if (eMarkType
!= SC_MARK_SIMPLE
&& eMarkType
!= SC_MARK_SIMPLE_FILTERED
)
1170 rSet
.DisableItem( nWhich
);
1172 else if (rDoc
.GetDPAtBlock(aDummy
))
1174 rSet
.DisableItem( nWhich
);
1177 rSet
.Put( SfxBoolItem( nWhich
, bAutoFilter
) );
1181 rSet
.DisableItem( nWhich
);
1187 SCCOL nStartCol
, nEndCol
;
1188 SCROW nStartRow
, nEndRow
;
1189 SCTAB nStartTab
, nEndTab
;
1190 bool bAnyQuery
= false;
1192 bool bSelected
= (GetViewData().GetSimpleArea(
1193 nStartCol
, nStartRow
, nStartTab
, nEndCol
, nEndRow
, nEndTab
)
1198 if (nStartCol
==nEndCol
&& nStartRow
==nEndRow
)
1203 nStartCol
= GetViewData().GetCurX();
1204 nStartRow
= GetViewData().GetCurY();
1205 nStartTab
= GetViewData().GetTabNo();
1208 ScDBData
* pDBData
= bSelected
1209 ? rDoc
.GetDBAtArea( nStartTab
, nStartCol
, nStartRow
, nEndCol
, nEndRow
)
1210 : rDoc
.GetDBAtCursor( nStartCol
, nStartRow
, nStartTab
, ScDBDataPortion::AREA
);
1214 ScQueryParam aParam
;
1215 pDBData
->GetQueryParam( aParam
);
1216 if ( aParam
.GetEntry(0).bDoQuery
)
1221 rSet
.DisableItem( nWhich
);
1225 case SID_DEFINE_DBNAME
:
1227 if ( pDocSh
->IsDocShared() )
1229 rSet
.DisableItem( nWhich
);
1233 case SID_DATA_PROVIDER
:
1235 case SID_DATA_PROVIDER_REFRESH
:
1237 ScDocument
& rViewDoc
= GetViewData().GetDocument();
1238 auto& rDataMapper
= rViewDoc
.GetExternalDataMapper();
1239 if (rDataMapper
.getDataSources().empty())
1240 rSet
.DisableItem(nWhich
);
1243 case SID_DATA_STREAMS
:
1244 case SID_DATA_STREAMS_PLAY
:
1245 case SID_DATA_STREAMS_STOP
:
1247 if ( !officecfg::Office::Common::Misc::ExperimentalMode::get() )
1248 rSet
.DisableItem( nWhich
);
1251 case SID_TEXT_TO_COLUMNS
:
1254 if ( !lcl_GetTextToColumnsRange( rData
, aRange
, true ) )
1256 rSet
.DisableItem( nWhich
);
1260 case SID_MANAGE_XML_SOURCE
:
1263 nWhich
= aIter
.NextWhich();
1267 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */