| /************************************************************** |
| * |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| *************************************************************/ |
| |
| |
| |
| // MARKER(update_precomp.py): autogen include statement, do not remove |
| #include "precompiled_sc.hxx" |
| |
| |
| |
| //------------------------------------------------------------------ |
| |
| #include "scitems.hxx" |
| #include <svl/srchitem.hxx> |
| #include <sfx2/app.hxx> |
| #include <sfx2/objface.hxx> |
| #include <sfx2/objsh.hxx> |
| #include <sfx2/request.hxx> |
| #include <svl/whiter.hxx> |
| #include <vcl/msgbox.hxx> |
| #include <sfx2/sidebar/EnumContext.hxx> |
| |
| #include "sc.hrc" |
| #include "pivotsh.hxx" |
| #include "tabvwsh.hxx" |
| #include "docsh.hxx" |
| #include "scresid.hxx" |
| #include "document.hxx" |
| #include "dpobject.hxx" |
| #include "dpshttab.hxx" |
| #include "dbdocfun.hxx" |
| #include "uiitems.hxx" |
| //CHINA001 #include "pfiltdlg.hxx" |
| #include "scabstdlg.hxx" //CHINA001 |
| //------------------------------------------------------------------------ |
| |
| #define ScPivotShell |
| #include "scslots.hxx" |
| |
| //------------------------------------------------------------------------ |
| |
| TYPEINIT1( ScPivotShell, SfxShell ); |
| |
| SFX_IMPL_INTERFACE(ScPivotShell, SfxShell, ScResId(SCSTR_PIVOTSHELL)) |
| { |
| SFX_POPUPMENU_REGISTRATION( ScResId(RID_POPUP_PIVOT) ); |
| } |
| |
| |
| //------------------------------------------------------------------------ |
| |
| ScPivotShell::ScPivotShell( ScTabViewShell* pViewSh ) : |
| SfxShell(pViewSh), |
| pViewShell( pViewSh ) |
| { |
| SetPool( &pViewSh->GetPool() ); |
| ScViewData* pViewData = pViewSh->GetViewData(); |
| ::svl::IUndoManager* pMgr = pViewData->GetSfxDocShell()->GetUndoManager(); |
| SetUndoManager( pMgr ); |
| if ( !pViewData->GetDocument()->IsUndoEnabled() ) |
| { |
| pMgr->SetMaxUndoActionCount( 0 ); |
| } |
| SetHelpId( HID_SCSHELL_PIVOTSH ); |
| SetName(String::CreateFromAscii(RTL_CONSTASCII_STRINGPARAM("Pivot"))); |
| SfxShell::SetContextName(sfx2::sidebar::EnumContext::GetContextName(sfx2::sidebar::EnumContext::Context_Pivot)); |
| } |
| |
| //------------------------------------------------------------------------ |
| ScPivotShell::~ScPivotShell() |
| { |
| } |
| |
| //------------------------------------------------------------------------ |
| void ScPivotShell::Execute( SfxRequest& rReq ) |
| { |
| switch ( rReq.GetSlot() ) |
| { |
| case SID_PIVOT_RECALC: |
| pViewShell->RecalcPivotTable(); |
| break; |
| |
| case SID_PIVOT_KILL: |
| pViewShell->DeletePivotTable(); |
| break; |
| |
| case SID_DP_FILTER: |
| { |
| ScDPObject* pDPObj = GetCurrDPObject(); |
| if( pDPObj ) |
| { |
| ScQueryParam aQueryParam; |
| SCTAB nSrcTab = 0; |
| const ScSheetSourceDesc* pDesc = pDPObj->GetSheetDesc(); |
| DBG_ASSERT( pDesc, "no sheet source for DP filter dialog" ); |
| if( pDesc ) |
| { |
| aQueryParam = pDesc->aQueryParam; |
| nSrcTab = pDesc->aSourceRange.aStart.Tab(); |
| } |
| |
| ScViewData* pViewData = pViewShell->GetViewData(); |
| SfxItemSet aArgSet( pViewShell->GetPool(), |
| SCITEM_QUERYDATA, SCITEM_QUERYDATA ); |
| aArgSet.Put( ScQueryItem( SCITEM_QUERYDATA, pViewData, &aQueryParam ) ); |
| |
| //CHINA001 ScPivotFilterDlg* pDlg = new ScPivotFilterDlg( |
| //CHINA001 pViewShell->GetDialogParent(), aArgSet, nSrcTab ); |
| |
| ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create(); |
| DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001 |
| |
| AbstractScPivotFilterDlg* pDlg = pFact->CreateScPivotFilterDlg( pViewShell->GetDialogParent(), |
| aArgSet, nSrcTab, |
| RID_SCDLG_PIVOTFILTER); |
| DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001 |
| |
| if( pDlg->Execute() == RET_OK ) |
| { |
| ScSheetSourceDesc aNewDesc; |
| if( pDesc ) |
| aNewDesc = *pDesc; |
| |
| const ScQueryItem& rQueryItem = pDlg->GetOutputItem(); |
| aNewDesc.aQueryParam = rQueryItem.GetQueryData(); |
| |
| ScDPObject aNewObj( *pDPObj ); |
| aNewObj.SetSheetDesc( aNewDesc ); |
| ScDBDocFunc aFunc( *pViewData->GetDocShell() ); |
| aFunc.DataPilotUpdate( pDPObj, &aNewObj, sal_True, sal_False ); |
| pViewData->GetView()->CursorPosChanged(); // shells may be switched |
| } |
| delete pDlg; |
| } |
| } |
| break; |
| } |
| } |
| |
| //------------------------------------------------------------------------ |
| void __EXPORT ScPivotShell::GetState( SfxItemSet& rSet ) |
| { |
| ScDocShell* pDocSh = pViewShell->GetViewData()->GetDocShell(); |
| ScDocument* pDoc = pDocSh->GetDocument(); |
| sal_Bool bDisable = pDocSh->IsReadOnly() || pDoc->GetChangeTrack(); |
| |
| SfxWhichIter aIter(rSet); |
| sal_uInt16 nWhich = aIter.FirstWhich(); |
| while (nWhich) |
| { |
| switch (nWhich) |
| { |
| case SID_PIVOT_RECALC: |
| case SID_PIVOT_KILL: |
| { |
| //! move ReadOnly check to idl flags |
| if ( bDisable ) |
| { |
| rSet.DisableItem( nWhich ); |
| } |
| } |
| break; |
| case SID_DP_FILTER: |
| { |
| ScDPObject* pDPObj = GetCurrDPObject(); |
| if( bDisable || !pDPObj || !pDPObj->IsSheetData() ) |
| rSet.DisableItem( nWhich ); |
| } |
| break; |
| } |
| nWhich = aIter.NextWhich(); |
| } |
| } |
| |
| |
| //------------------------------------------------------------------------ |
| |
| ScDPObject* ScPivotShell::GetCurrDPObject() |
| { |
| const ScViewData& rViewData = *pViewShell->GetViewData(); |
| return rViewData.GetDocument()->GetDPAtCursor( |
| rViewData.GetCurX(), rViewData.GetCurY(), rViewData.GetTabNo() ); |
| } |