blob: 06bc76e05b684cae8f63205bcc21e9f86c26e3d6 [file] [log] [blame]
/**************************************************************
*
* 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"
//------------------------------------------------------------------
//svdraw.hxx
#define _SDR_NOITEMS
#define _SDR_NOTOUCH
#define _SDR_NOTRANSFORM
#define _SI_NOSBXCONTROLS
#define _VCONT_HXX
#define _SI_NOOTHERFORMS
#define _VCTRLS_HXX
#define _SI_NOCONTROL
#define _SETBRW_HXX
#define _VCBRW_HXX
#define _SI_NOSBXCONTROLS
//------------------------------------------------------------------
#include <com/sun/star/i18n/TextConversionOption.hpp>
#include <com/sun/star/sheet/DataPilotFieldFilter.hpp>
#include "scitems.hxx"
#include <sfx2/viewfrm.hxx>
#define _ZFORLIST_DECLARE_TABLE
#include <svl/stritem.hxx>
#include <svl/whiter.hxx>
#include <svl/zforlist.hxx>
#include <svl/zformat.hxx>
#include <sfx2/dispatch.hxx>
#include <sfx2/request.hxx>
#include <vcl/msgbox.hxx>
#include <svx/svxdlg.hxx>
#include <sot/formats.hxx>
#include <svx/postattr.hxx>
#include <editeng/fontitem.hxx>
#include <svx/clipfmtitem.hxx>
#include <sfx2/passwd.hxx>
#include <svx/hlnkitem.hxx>
#include <basic/sbxcore.hxx>
#include <unotools/useroptions.hxx>
#include <vcl/waitobj.hxx>
#include <unotools/localedatawrapper.hxx>
#include "cellsh.hxx"
#include "sc.hrc"
#include "document.hxx"
#include "patattr.hxx"
#include "scmod.hxx"
#include "scresid.hxx"
#include "tabvwsh.hxx"
//CHINA001 #include "inscldlg.hxx"
//CHINA001 #include "inscodlg.hxx"
//CHINA001 #include "delcldlg.hxx"
//CHINA001 #include "delcodlg.hxx"
//CHINA001 #include "filldlg.hxx"
//CHINA001 #include "groupdlg.hxx"
#include "impex.hxx"
#include "reffind.hxx"
//CHINA001 #include "namecrea.hxx"
#include "uiitems.hxx"
#include "reffact.hxx"
//CHINA001 #include "namepast.hxx"
#include "inputhdl.hxx"
#include "transobj.hxx"
#include "drwtrans.hxx"
//CHINA001 #include "linkarea.hxx"
#include "docfunc.hxx"
#include "editable.hxx"
#include "dpobject.hxx"
#include "dpsave.hxx"
#include "dpgroup.hxx" // for ScDPNumGroupInfo
#include "spellparam.hxx"
#include "postit.hxx"
#include "clipparam.hxx"
#include "globstr.hrc"
#include "scui_def.hxx" //CHINA001
#include <svx/svxdlg.hxx> //CHINA001
#include <svx/dialogs.hrc> //CHINA001
#include "scabstdlg.hxx" //CHINA001
#define IS_AVAILABLE(WhichId,ppItem) \
(pReqArgs->GetItemState((WhichId), sal_True, ppItem ) == SFX_ITEM_SET)
#define C2U(cChar) rtl::OUString::createFromAscii(cChar)
#include <com/sun/star/ui/dialogs/XExecutableDialog.hpp>
#include <com/sun/star/lang/XInitialization.hpp>
#include <com/sun/star/beans/PropertyValue.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <cppuhelper/bootstrap.hxx>
using namespace ::com::sun::star;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::uno;
//------------------------------------------------------------------
void ScCellShell::ExecuteEdit( SfxRequest& rReq )
{
ScModule* pScMod = SC_MOD();
ScTabViewShell* pTabViewShell = GetViewData()->GetViewShell();
SfxBindings& rBindings = pTabViewShell->GetViewFrame()->GetBindings();
const SfxItemSet* pReqArgs = rReq.GetArgs();
sal_uInt16 nSlot = rReq.GetSlot();
pTabViewShell->HideListBox(); // Autofilter-DropDown-Listbox
// Eingabe beenden
if ( GetViewData()->HasEditView( GetViewData()->GetActivePart() ) )
{
switch ( nSlot )
{
case FID_DEFINE_NAME:
case FID_USE_NAME:
case FID_INSERT_NAME:
case SID_SPELL_DIALOG:
case SID_HANGUL_HANJA_CONVERSION:
pScMod->InputEnterHandler();
pTabViewShell->UpdateInputHandler();
break;
default:
break;
}
}
switch ( nSlot )
{
//
// Einfuegen / Loeschen von Zellen / Zeilen / Spalten
//
case FID_INS_ROW:
pTabViewShell->InsertCells(INS_INSROWS);
rReq.Done();
break;
case FID_INS_COLUMN:
pTabViewShell->InsertCells(INS_INSCOLS);
rReq.Done();
break;
case FID_INS_CELLSDOWN:
pTabViewShell->InsertCells(INS_CELLSDOWN);
rReq.Done();
break;
case FID_INS_CELLSRIGHT:
pTabViewShell->InsertCells(INS_CELLSRIGHT);
rReq.Done();
break;
case SID_DEL_ROWS:
pTabViewShell->DeleteCells( DEL_DELROWS );
rReq.Done();
break;
case SID_DEL_COLS:
pTabViewShell->DeleteCells( DEL_DELCOLS );
rReq.Done();
break;
case FID_INS_CELL:
{
InsCellCmd eCmd=INS_NONE;
if ( pReqArgs )
{
const SfxPoolItem* pItem;
String aFlags;
if( IS_AVAILABLE( FID_INS_CELL, &pItem ) )
aFlags = ((const SfxStringItem*)pItem)->GetValue();
if( aFlags.Len() )
{
switch( aFlags.GetChar(0) )
{
case 'V': eCmd = INS_CELLSDOWN ;break;
case '>': eCmd = INS_CELLSRIGHT ;break;
case 'R': eCmd = INS_INSROWS ;break;
case 'C': eCmd = INS_INSCOLS ;break;
}
}
}
else
{
if ( GetViewData()->SimpleColMarked() )
eCmd = INS_INSCOLS;
else if ( GetViewData()->SimpleRowMarked() )
eCmd = INS_INSROWS;
else
{
ScDocument* pDoc = GetViewData()->GetDocument();
sal_Bool bTheFlag=(pDoc->GetChangeTrack()!=NULL);
//CHINA001 ScInsertCellDlg* pDlg = new ScInsertCellDlg( pTabViewShell->GetDialogParent(),
//CHINA001 bTheFlag);
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScInsertCellDlg* pDlg = pFact->CreateScInsertCellDlg( pTabViewShell->GetDialogParent(), RID_SCDLG_INSCELL, bTheFlag);
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if (pDlg->Execute() == RET_OK)
eCmd = pDlg->GetInsCellCmd();
delete pDlg;
}
}
if (eCmd!=INS_NONE)
{
pTabViewShell->InsertCells( eCmd );
if( ! rReq.IsAPI() )
{
String aParam;
switch( eCmd )
{
case INS_CELLSDOWN: aParam='V'; break;
case INS_CELLSRIGHT: aParam='>'; break;
case INS_INSROWS: aParam='R'; break;
case INS_INSCOLS: aParam='C'; break;
default:
{
// added to avoid warnings
}
}
rReq.AppendItem( SfxStringItem( FID_INS_CELL, aParam ) );
rReq.Done();
}
}
}
break;
case FID_DELETE_CELL:
{
DelCellCmd eCmd = DEL_NONE;
if ( pReqArgs )
{
const SfxPoolItem* pItem;
String aFlags;
if( IS_AVAILABLE( FID_DELETE_CELL, &pItem ) )
aFlags = ((const SfxStringItem*)pItem)->GetValue();
if( aFlags.Len() )
{
switch( aFlags.GetChar(0) )
{
case 'U': eCmd = DEL_CELLSUP ;break;
case 'L': eCmd = DEL_CELLSLEFT ;break;
case 'R': eCmd = DEL_DELROWS ;break;
case 'C': eCmd = DEL_DELCOLS ;break;
}
}
}
else
{
if ( GetViewData()->SimpleColMarked() )
eCmd = DEL_DELCOLS;
else if ( GetViewData()->SimpleRowMarked() )
eCmd = DEL_DELROWS;
else
{
ScRange aRange;
ScDocument* pDoc = GetViewData()->GetDocument();
sal_Bool bTheFlag=GetViewData()->IsMultiMarked() ||
(GetViewData()->GetSimpleArea(aRange) == SC_MARK_SIMPLE_FILTERED) ||
(pDoc->GetChangeTrack() != NULL);
//CHINA001 ScDeleteCellDlg* pDlg = new ScDeleteCellDlg(
//CHINA001 pTabViewShell->GetDialogParent(),bTheFlag);
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScDeleteCellDlg* pDlg = pFact->CreateScDeleteCellDlg( pTabViewShell->GetDialogParent(), RID_SCDLG_DELCELL, bTheFlag );
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if (pDlg->Execute() == RET_OK)
eCmd = pDlg->GetDelCellCmd();
delete pDlg;
}
}
if (eCmd != DEL_NONE )
{
pTabViewShell->DeleteCells( eCmd );
if( ! rReq.IsAPI() )
{
String aParam;
switch( eCmd )
{
case DEL_CELLSUP: aParam='U'; break;
case DEL_CELLSLEFT: aParam='L'; break;
case DEL_DELROWS: aParam='R'; break;
case DEL_DELCOLS: aParam='C'; break;
default:
{
// added to avoid warnings
}
}
rReq.AppendItem( SfxStringItem( FID_DELETE_CELL, aParam ) );
rReq.Done();
}
}
}
break;
//
// Inhalte von Zellen loeschen
//
case SID_DELETE_CONTENTS:
pTabViewShell->DeleteContents( IDF_CONTENTS );
rReq.Done();
break;
case SID_DELETE:
{
sal_uInt16 nFlags = IDF_NONE;
if ( pReqArgs!=NULL && pTabViewShell->SelectionEditable() )
{
const SfxPoolItem* pItem;
String aFlags = 'A';
if( IS_AVAILABLE( SID_DELETE, &pItem ) )
aFlags = ((const SfxStringItem*)pItem)->GetValue();
aFlags.ToUpperAscii();
sal_Bool bCont = sal_True;
for( xub_StrLen i=0 ; bCont && i<aFlags.Len() ; i++ )
{
switch( aFlags.GetChar(i) )
{
case 'A': // Alle
nFlags |= IDF_ALL;
bCont = sal_False; // nicht mehr weitermachen!
break;
case 'S': nFlags |= IDF_STRING; break;
case 'V': nFlags |= IDF_VALUE; break;
case 'D': nFlags |= IDF_DATETIME; break;
case 'F': nFlags |= IDF_FORMULA; break;
case 'N': nFlags |= IDF_NOTE; break;
case 'T': nFlags |= IDF_ATTRIB; break;
case 'O': nFlags |= IDF_OBJECTS; break;
}
}
}
else
{
ScEditableTester aTester( pTabViewShell );
if (aTester.IsEditable())
{
//CHINA001 ScDeleteContentsDlg* pDlg = new ScDeleteContentsDlg( pTabViewShell->GetDialogParent() );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScDeleteContentsDlg* pDlg = pFact->CreateScDeleteContentsDlg( pTabViewShell->GetDialogParent(), RID_SCDLG_DELCONT );
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
ScDocument* pDoc = GetViewData()->GetDocument();
SCTAB nTab = GetViewData()->GetTabNo();
if ( pDoc->IsTabProtected(nTab) )
pDlg->DisableObjects();
if (pDlg->Execute() == RET_OK)
{
nFlags = pDlg->GetDelContentsCmdBits();
}
delete pDlg;
}
else
pTabViewShell->ErrorMessage(aTester.GetMessageId());
}
if( nFlags != IDF_NONE )
{
pTabViewShell->DeleteContents( nFlags );
if( ! rReq.IsAPI() )
{
String aFlags;
if( nFlags == IDF_ALL )
{
aFlags += 'A';
}
else
{
if( nFlags & IDF_STRING ) aFlags += 'S';
if( nFlags & IDF_VALUE ) aFlags += 'V';
if( nFlags & IDF_DATETIME ) aFlags += 'D';
if( nFlags & IDF_FORMULA ) aFlags += 'F';
if( nFlags & IDF_NOTE ) aFlags += 'N';
if( nFlags & IDF_ATTRIB ) aFlags += 'T';
if( nFlags & IDF_OBJECTS ) aFlags += 'O';
}
rReq.AppendItem( SfxStringItem( SID_DELETE, aFlags ) );
rReq.Done();
}
}
}
break;
//
// Ausfuellen...
//
case FID_FILL_TO_BOTTOM:
pTabViewShell->FillSimple( FILL_TO_BOTTOM );
rReq.Done();
break;
case FID_FILL_TO_RIGHT:
pTabViewShell->FillSimple( FILL_TO_RIGHT );
rReq.Done();
break;
case FID_FILL_TO_TOP:
pTabViewShell->FillSimple( FILL_TO_TOP );
rReq.Done();
break;
case FID_FILL_TO_LEFT:
pTabViewShell->FillSimple( FILL_TO_LEFT );
rReq.Done();
break;
case FID_FILL_TAB:
{
sal_uInt16 nFlags = IDF_NONE;
sal_uInt16 nFunction = PASTE_NOFUNC;
sal_Bool bSkipEmpty = sal_False;
sal_Bool bAsLink = sal_False;
if ( pReqArgs!=NULL && pTabViewShell->SelectionEditable() )
{
const SfxPoolItem* pItem;
String aFlags = 'A';
if( IS_AVAILABLE( FID_FILL_TAB, &pItem ) )
aFlags = ((const SfxStringItem*)pItem)->GetValue();
aFlags.ToUpperAscii();
sal_Bool bCont = sal_True;
for( xub_StrLen i=0 ; bCont && i<aFlags.Len() ; i++ )
{
switch( aFlags.GetChar(i) )
{
case 'A': // Alle
nFlags |= IDF_ALL;
bCont = sal_False; // nicht mehr weitermachen!
break;
case 'S': nFlags |= IDF_STRING; break;
case 'V': nFlags |= IDF_VALUE; break;
case 'D': nFlags |= IDF_DATETIME; break;
case 'F': nFlags |= IDF_FORMULA; break;
case 'N': nFlags |= IDF_NOTE; break;
case 'T': nFlags |= IDF_ATTRIB; break;
}
}
}
else
{
//CHINA001 ScInsertContentsDlg* pDlg =
//CHINA001 new ScInsertContentsDlg(pTabViewShell->GetDialogParent(),
//CHINA001 0, /* nCheckDefaults */
//CHINA001 &ScGlobal::GetRscString(STR_FILL_TAB) );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScInsertContentsDlg* pDlg = pFact->CreateScInsertContentsDlg( pTabViewShell->GetDialogParent(),
RID_SCDLG_INSCONT, 0, /* nCheckDefaults */
&ScGlobal::GetRscString(STR_FILL_TAB));
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
pDlg->SetFillMode(sal_True);
if (pDlg->Execute() == RET_OK)
{
nFlags = pDlg->GetInsContentsCmdBits();
nFunction = pDlg->GetFormulaCmdBits();
bSkipEmpty = pDlg->IsSkipEmptyCells();
bAsLink = pDlg->IsLink();
// MoveMode gibt's bei Tabelle fuellen nicht
}
delete pDlg;
}
if( nFlags != IDF_NONE )
{
pTabViewShell->FillTab( nFlags, nFunction, bSkipEmpty, bAsLink );
if( ! rReq.IsAPI() )
{
String aFlags;
if( nFlags == IDF_ALL )
{
aFlags += 'A';
}
else
{
if( nFlags & IDF_STRING ) aFlags += 'S';
if( nFlags & IDF_VALUE ) aFlags += 'V';
if( nFlags & IDF_DATETIME ) aFlags += 'D';
if( nFlags & IDF_FORMULA ) aFlags += 'F';
if( nFlags & IDF_NOTE ) aFlags += 'N';
if( nFlags & IDF_ATTRIB ) aFlags += 'T';
}
rReq.AppendItem( SfxStringItem( FID_FILL_TAB, aFlags ) );
rReq.Done();
}
}
}
break;
case FID_FILL_SERIES:
{
SCCOL nStartCol;
SCROW nStartRow;
SCTAB nStartTab;
SCCOL nEndCol;
SCROW nEndRow;
SCTAB nEndTab;
sal_uInt16 nPossDir = FDS_OPT_NONE;
FillDir eFillDir = FILL_TO_BOTTOM;
FillCmd eFillCmd = FILL_LINEAR;
FillDateCmd eFillDateCmd = FILL_DAY;
double fStartVal = MAXDOUBLE;
double fIncVal = 1;
double fMaxVal = MAXDOUBLE;
sal_Bool bDoIt = sal_False;
GetViewData()->GetSimpleArea( nStartCol, nStartRow, nStartTab,
nEndCol, nEndRow, nEndTab );
if( nStartCol!=nEndCol )
{
nPossDir |= FDS_OPT_HORZ;
eFillDir=FILL_TO_RIGHT;
}
if( nStartRow!=nEndRow )
{
nPossDir |= FDS_OPT_VERT;
eFillDir=FILL_TO_BOTTOM;
}
ScDocument* pDoc = GetViewData()->GetDocument();
SvNumberFormatter* pFormatter = pDoc->GetFormatTable();
if( pReqArgs )
{
const SfxPoolItem* pItem;
String aFillDir, aFillCmd, aFillDateCmd;
String aFillStep, aFillStart, aFillMax;
sal_uInt32 nKey;
double fTmpVal;
bDoIt=sal_False;
if( IS_AVAILABLE( FID_FILL_SERIES, &pItem ) )
aFillDir = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_1, &pItem ) )
aFillCmd = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_2, &pItem ) )
aFillDateCmd = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_3, &pItem ) )
aFillStep = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_4, &pItem ) )
aFillStart = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_5, &pItem ) )
aFillMax = ((const SfxStringItem*)pItem)->GetValue();
if( aFillDir.Len() )
switch( aFillDir.GetChar(0) )
{
case 'B': case 'b': eFillDir=FILL_TO_BOTTOM; break;
case 'R': case 'r': eFillDir=FILL_TO_RIGHT; break;
case 'T': case 't': eFillDir=FILL_TO_TOP; break;
case 'L': case 'l': eFillDir=FILL_TO_LEFT; break;
}
if( aFillCmd.Len() )
switch( aFillCmd.GetChar(0) )
{
case 'S': case 's': eFillCmd=FILL_SIMPLE; break;
case 'L': case 'l': eFillCmd=FILL_LINEAR; break;
case 'G': case 'g': eFillCmd=FILL_GROWTH; break;
case 'D': case 'd': eFillCmd=FILL_DATE; break;
case 'A': case 'a': eFillCmd=FILL_AUTO; break;
}
if( aFillDateCmd.Len() )
switch( aFillDateCmd.GetChar(0) )
{
case 'D': case 'd': eFillDateCmd=FILL_DAY; break;
case 'W': case 'w': eFillDateCmd=FILL_WEEKDAY; break;
case 'M': case 'm': eFillDateCmd=FILL_MONTH; break;
case 'Y': case 'y': eFillDateCmd=FILL_YEAR; break;
}
nKey = 0;
if( pFormatter->IsNumberFormat( aFillStart, nKey, fTmpVal ))
fStartVal = fTmpVal;
nKey = 0;
if( pFormatter->IsNumberFormat( aFillStep, nKey, fTmpVal ))
fIncVal = fTmpVal;
nKey = 0;
if( pFormatter->IsNumberFormat( aFillMax, nKey, fTmpVal ))
fMaxVal = fTmpVal;
bDoIt = sal_True;
}
else // (pReqArgs == NULL) => Dialog hochziehen
{
//
sal_uInt32 nPrivFormat;
CellType eCellType;
pDoc->GetNumberFormat( nStartCol, nStartRow, nStartTab, nPrivFormat );
pDoc->GetCellType( nStartCol, nStartRow, nStartTab,eCellType );
const SvNumberformat* pPrivEntry = pFormatter->GetEntry( nPrivFormat );
if (!pPrivEntry)
{
DBG_ERROR("Zahlformat nicht gefunden !!!");
}
else
{
short nPrivType = pPrivEntry->GetType();
if ( ( nPrivType & NUMBERFORMAT_DATE)>0)
{
eFillCmd=FILL_DATE;
}
else if(eCellType==CELLTYPE_STRING)
{
eFillCmd=FILL_AUTO;
}
}
//
String aStartStr;
// Startwert nur vorbelegen, wenn nur 1 Zeile oder Spalte:
if ( nStartCol == nEndCol || nStartRow == nEndRow )
{
double fInputEndVal = 0.0;
String aEndStr;
pDoc->GetInputString( nStartCol, nStartRow, nStartTab, aStartStr);
pDoc->GetValue( nStartCol, nStartRow, nStartTab, fStartVal );
if(eFillDir==FILL_TO_BOTTOM && nStartRow < nEndRow )
{
pDoc->GetInputString( nStartCol, nStartRow+1, nStartTab, aEndStr);
if(aEndStr.Len()>0)
{
pDoc->GetValue( nStartCol, nStartRow+1, nStartTab, fInputEndVal);
fIncVal=fInputEndVal-fStartVal;
}
}
else
{
if(nStartCol < nEndCol)
{
pDoc->GetInputString( nStartCol+1, nStartRow, nStartTab, aEndStr);
if(aEndStr.Len()>0)
{
pDoc->GetValue( nStartCol+1, nStartRow, nStartTab, fInputEndVal);
fIncVal=fInputEndVal-fStartVal;
}
}
}
if(eFillCmd==FILL_DATE)
{
Date aNullDate = *pDoc->GetFormatTable()->GetNullDate();
Date aStartDate = aNullDate;
aStartDate+= (long)fStartVal;
Date aEndDate = aNullDate;
aEndDate+= (long)fInputEndVal;
double fTempDate=0;
if(aStartDate.GetYear()!=aEndDate.GetYear())
{
eFillDateCmd = FILL_YEAR;
fTempDate=aEndDate.GetYear()-aStartDate.GetYear();
}
if(aStartDate.GetMonth()!=aEndDate.GetMonth())
{
eFillDateCmd = FILL_MONTH;
fTempDate=fTempDate*12+aEndDate.GetMonth()-aStartDate.GetMonth();
}
if(aStartDate.GetDay()==aEndDate.GetDay())
{
fIncVal=fTempDate;
}
}
}
//CHINA001 ScFillSeriesDlg* pDlg = new ScFillSeriesDlg(
//CHINA001 pTabViewShell->GetDialogParent(), *pDoc,
//CHINA001 eFillDir, eFillCmd, eFillDateCmd,
//CHINA001 aStartStr, fIncVal, fMaxVal,
//CHINA001 nPossDir);
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScFillSeriesDlg* pDlg = pFact->CreateScFillSeriesDlg( pTabViewShell->GetDialogParent(),
*pDoc,
eFillDir, eFillCmd, eFillDateCmd,
aStartStr, fIncVal, fMaxVal,
nPossDir,
RID_SCDLG_FILLSERIES);
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if ( nStartCol != nEndCol && nStartRow != nEndRow )
{
pDlg->SetEdStartValEnabled(sal_False);
}
if ( pDlg->Execute() == RET_OK )
{
eFillDir = pDlg->GetFillDir();
eFillCmd = pDlg->GetFillCmd();
eFillDateCmd = pDlg->GetFillDateCmd();
if(eFillCmd==FILL_AUTO)
{
String aStr=pDlg->GetStartStr();
if(aStr.Len()>0)
pTabViewShell->EnterData( nStartCol, nStartRow, nStartTab, aStr );
}
fStartVal = pDlg->GetStart();
fIncVal = pDlg->GetStep();
fMaxVal = pDlg->GetMax();
bDoIt = sal_True;
}
delete pDlg;
}
if( bDoIt )
{
//nScFillModeMouseModifier = 0; // kein Ctrl/Copy
pTabViewShell->FillSeries( eFillDir, eFillCmd, eFillDateCmd, fStartVal, fIncVal, fMaxVal );
if( ! rReq.IsAPI() )
{
String aPara;
Color* pColor=0;
switch( eFillDir )
{
case FILL_TO_BOTTOM: aPara = 'B'; break;
case FILL_TO_RIGHT: aPara = 'R'; break;
case FILL_TO_TOP: aPara = 'T'; break;
case FILL_TO_LEFT: aPara = 'L'; break;
default: aPara.Erase(); break;
}
rReq.AppendItem( SfxStringItem( FID_FILL_SERIES, aPara ) );
switch( eFillCmd )
{
case FILL_SIMPLE: aPara = 'S'; break;
case FILL_LINEAR: aPara = 'L'; break;
case FILL_GROWTH: aPara = 'G'; break;
case FILL_DATE: aPara = 'D'; break;
case FILL_AUTO: aPara = 'A'; break;
default: aPara.Erase(); break;
}
rReq.AppendItem( SfxStringItem( FN_PARAM_1, aPara ) );
switch( eFillDateCmd )
{
case FILL_DAY: aPara = 'D'; break;
case FILL_WEEKDAY: aPara = 'W'; break;
case FILL_MONTH: aPara = 'M'; break;
case FILL_YEAR: aPara = 'Y'; break;
default: aPara.Erase(); break;
}
rReq.AppendItem( SfxStringItem( FN_PARAM_2, aPara ) );
sal_uLong nFormatKey = pFormatter->GetStandardFormat(NUMBERFORMAT_NUMBER,
ScGlobal::eLnge );
pFormatter->GetOutputString( fIncVal, nFormatKey, aPara, &pColor );
rReq.AppendItem( SfxStringItem( FN_PARAM_3, aPara ) );
pFormatter->GetOutputString( fStartVal, nFormatKey, aPara, &pColor );
rReq.AppendItem( SfxStringItem( FN_PARAM_4, aPara ) );
pFormatter->GetOutputString( fMaxVal, nFormatKey, aPara, &pColor );
rReq.AppendItem( SfxStringItem( FN_PARAM_5, aPara ) );
rReq.Done();
}
}
}
break;
case FID_FILL_AUTO:
{
SCCOL nStartCol;
SCROW nStartRow;
SCCOL nEndCol;
SCROW nEndRow;
SCTAB nStartTab, nEndTab;
GetViewData()->GetFillData( nStartCol, nStartRow, nEndCol, nEndRow );
SCCOL nFillCol = GetViewData()->GetRefEndX();
SCROW nFillRow = GetViewData()->GetRefEndY();
ScDocument* pDoc = GetViewData()->GetDocument();
if( pReqArgs != NULL )
{
const SfxPoolItem* pItem;
if( IS_AVAILABLE( FID_FILL_AUTO, &pItem ) )
{
ScAddress aScAddress;
String aArg = ((const SfxStringItem*)pItem)->GetValue();
if( aScAddress.Parse( aArg, pDoc, pDoc->GetAddressConvention() ) & SCA_VALID )
{
nFillRow = aScAddress.Row();
nFillCol = aScAddress.Col();
}
}
GetViewData()->GetSimpleArea( nStartCol,nStartRow,nStartTab,
nEndCol,nEndRow,nEndTab );
}
else // Aufruf per Maus
{
// #55284# nicht innerhalb einer zusammengefassten Zelle
if ( nStartCol == nEndCol && nStartRow == nEndRow )
{
SCCOL nMergeCol = nStartCol;
SCROW nMergeRow = nStartRow;
if ( GetViewData()->GetDocument()->ExtendMerge(
nStartCol, nStartRow, nMergeCol, nMergeRow,
GetViewData()->GetTabNo() ) )
{
if ( nFillCol >= nStartCol && nFillCol <= nMergeCol && nFillRow == nStartRow )
nFillCol = nStartCol;
if ( nFillRow >= nStartRow && nFillRow <= nMergeRow && nFillCol == nStartCol )
nFillRow = nStartRow;
}
}
}
if ( nFillCol != nEndCol || nFillRow != nEndRow )
{
if ( nFillCol==nEndCol || nFillRow==nEndRow )
{
FillDir eDir = FILL_TO_BOTTOM;
SCCOLROW nCount = 0;
if ( nFillCol==nEndCol )
{
if ( nFillRow > nEndRow )
{
eDir = FILL_TO_BOTTOM;
nCount = nFillRow - nEndRow;
}
else if ( nFillRow < nStartRow )
{
eDir = FILL_TO_TOP;
nCount = nStartRow - nFillRow;
}
}
else
{
if ( nFillCol > nEndCol )
{
eDir = FILL_TO_RIGHT;
nCount = nFillCol - nEndCol;
}
else if ( nFillCol < nStartCol )
{
eDir = FILL_TO_LEFT;
nCount = nStartCol - nFillCol;
}
}
if ( nCount != 0)
{
pTabViewShell->FillAuto( eDir, nStartCol, nStartRow, nEndCol, nEndRow, nCount );
if( ! rReq.IsAPI() )
{
String aAdrStr;
ScAddress aAdr( nFillCol, nFillRow, 0 );
aAdr.Format( aAdrStr, SCR_ABS, pDoc, pDoc->GetAddressConvention() );
rReq.AppendItem( SfxStringItem( FID_FILL_AUTO, aAdrStr ) );
rReq.Done();
}
}
}
else
{
DBG_ERROR( "Richtung nicht eindeutig fuer AutoFill" );
}
}
}
break;
//
// Gliederung (Outlines)
// SID_AUTO_OUTLINE, SID_OUTLINE_DELETEALL in Execute (in docsh.idl)
//
case SID_OUTLINE_HIDE:
if ( GetViewData()->GetDocument()->GetDPAtCursor( GetViewData()->GetCurX(),
GetViewData()->GetCurY(), GetViewData()->GetTabNo() ) )
pTabViewShell->SetDataPilotDetails( sal_False );
else
pTabViewShell->HideMarkedOutlines();
rReq.Done();
break;
case SID_OUTLINE_SHOW:
{
ScDPObject* pDPObj = GetViewData()->GetDocument()->GetDPAtCursor( GetViewData()->GetCurX(),
GetViewData()->GetCurY(), GetViewData()->GetTabNo() );
if ( pDPObj )
{
Sequence<sheet::DataPilotFieldFilter> aFilters;
sal_uInt16 nOrientation;
if ( pTabViewShell->HasSelectionForDrillDown( nOrientation ) )
{
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScDPShowDetailDlg* pDlg = pFact->CreateScDPShowDetailDlg(
pTabViewShell->GetDialogParent(), RID_SCDLG_DPSHOWDETAIL, *pDPObj, nOrientation );
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if ( pDlg->Execute() == RET_OK )
{
String aNewDimName( pDlg->GetDimensionName() );
pTabViewShell->SetDataPilotDetails( sal_True, &aNewDimName );
}
}
else if ( !pDPObj->IsServiceData() &&
pDPObj->GetDataFieldPositionData(
ScAddress( GetViewData()->GetCurX(), GetViewData()->GetCurY(), GetViewData()->GetTabNo() ),
aFilters ) )
pTabViewShell->ShowDataPilotSourceData( *pDPObj, aFilters );
else
pTabViewShell->SetDataPilotDetails( sal_True );
}
else
pTabViewShell->ShowMarkedOutlines();
rReq.Done();
}
break;
case SID_OUTLINE_MAKE:
{
sal_Bool bColumns = sal_False;
sal_Bool bOk = sal_True;
if ( GetViewData()->GetDocument()->GetDPAtCursor( GetViewData()->GetCurX(),
GetViewData()->GetCurY(), GetViewData()->GetTabNo() ) )
{
ScDPNumGroupInfo aNumInfo;
aNumInfo.Enable = sal_True;
aNumInfo.AutoStart = sal_True;
aNumInfo.AutoEnd = sal_True;
sal_Int32 nParts = 0;
if ( pTabViewShell->HasSelectionForDateGroup( aNumInfo, nParts ) )
{
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT( pFact, "ScAbstractFactory create fail!" );
Date aNullDate( *GetViewData()->GetDocument()->GetFormatTable()->GetNullDate() );
AbstractScDPDateGroupDlg* pDlg = pFact->CreateScDPDateGroupDlg(
pTabViewShell->GetDialogParent(), RID_SCDLG_DPDATEGROUP,
aNumInfo, nParts, aNullDate );
DBG_ASSERT( pDlg, "Dialog create fail!" );
if( pDlg->Execute() == RET_OK )
{
aNumInfo = pDlg->GetGroupInfo();
pTabViewShell->DateGroupDataPilot( aNumInfo, pDlg->GetDatePart() );
}
}
else if ( pTabViewShell->HasSelectionForNumGroup( aNumInfo ) )
{
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT( pFact, "ScAbstractFactory create fail!" );
AbstractScDPNumGroupDlg* pDlg = pFact->CreateScDPNumGroupDlg(
pTabViewShell->GetDialogParent(), RID_SCDLG_DPNUMGROUP, aNumInfo );
DBG_ASSERT( pDlg, "Dialog create fail!" );
if( pDlg->Execute() == RET_OK )
pTabViewShell->NumGroupDataPilot( pDlg->GetGroupInfo() );
}
else
pTabViewShell->GroupDataPilot();
bOk = sal_False;
}
else if( pReqArgs != NULL )
{
const SfxPoolItem* pItem;
bOk = sal_False;
if( IS_AVAILABLE( SID_OUTLINE_MAKE, &pItem ) )
{
String aCol = ((const SfxStringItem*)pItem)->GetValue();
aCol.ToUpperAscii();
switch( aCol.GetChar(0) )
{
case 'R': bColumns=sal_False; bOk = sal_True;break;
case 'C': bColumns=sal_True; bOk = sal_True;break;
}
}
}
else // Dialog, wenn nicht ganze Zeilen/Spalten markiert
{
if ( GetViewData()->SimpleColMarked() && !GetViewData()->SimpleRowMarked() )
bColumns = sal_True;
else if ( !GetViewData()->SimpleColMarked() && GetViewData()->SimpleRowMarked() )
bColumns = sal_False;
else
{
//CHINA001 ScGroupDlg* pDlg = new ScGroupDlg(pTabViewShell->GetDialogParent(),
//CHINA001 RID_SCDLG_GRP_MAKE, sal_False );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScGroupDlg* pDlg = pFact->CreateAbstractScGroupDlg( pTabViewShell->GetDialogParent(), RID_SCDLG_GRP_MAKE, RID_SCDLG_GRP_MAKE,sal_False);
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if ( pDlg->Execute() == RET_OK )
bColumns = pDlg->GetColsChecked();
else
bOk = sal_False;
delete pDlg;
}
}
if (bOk)
{
pTabViewShell->MakeOutline( bColumns );
if( ! rReq.IsAPI() )
{
String aCol = bColumns ? 'C' : 'R';
rReq.AppendItem( SfxStringItem( SID_OUTLINE_MAKE, aCol ) );
rReq.Done();
}
}
}
break;
case SID_OUTLINE_REMOVE:
{
sal_Bool bColumns = sal_False;
sal_Bool bOk = sal_True;
if ( GetViewData()->GetDocument()->GetDPAtCursor( GetViewData()->GetCurX(),
GetViewData()->GetCurY(), GetViewData()->GetTabNo() ) )
{
pTabViewShell->UngroupDataPilot();
bOk = sal_False;
}
else if( pReqArgs != NULL )
{
const SfxPoolItem* pItem;
bOk = sal_False;
if( IS_AVAILABLE( SID_OUTLINE_REMOVE, &pItem ) )
{
String aCol = ((const SfxStringItem*)pItem)->GetValue();
aCol.ToUpperAscii();
switch( aCol.GetChar(0) )
{
case 'R': bColumns=sal_False; bOk = sal_True;break;
case 'C': bColumns=sal_True; bOk = sal_True;break;
}
}
}
else // Dialog nur, wenn Aufheben fuer Zeilen und Spalten moeglich
{
sal_Bool bColPoss, bRowPoss;
pTabViewShell->TestRemoveOutline( bColPoss, bRowPoss );
if ( bColPoss && bRowPoss )
{
//CHINA001 ScGroupDlg* pDlg = new ScGroupDlg( pTabViewShell->GetDialogParent(),
//CHINA001 RID_SCDLG_GRP_KILL, sal_True );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScGroupDlg* pDlg = pFact->CreateAbstractScGroupDlg( pTabViewShell->GetDialogParent(), RID_SCDLG_GRP_KILL, RID_SCDLG_GRP_KILL,sal_True);
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if ( pDlg->Execute() == RET_OK )
bColumns = pDlg->GetColsChecked();
else
bOk = sal_False;
delete pDlg;
}
else if ( bColPoss )
bColumns = sal_True;
else if ( bRowPoss )
bColumns = sal_False;
else
bOk = sal_False;
}
if (bOk)
{
pTabViewShell->RemoveOutline( bColumns );
if( ! rReq.IsAPI() )
{
String aCol = bColumns ? 'C' : 'R';
rReq.AppendItem( SfxStringItem( SID_OUTLINE_REMOVE, aCol ) );
rReq.Done();
}
}
}
break;
//
// Clipboard
//
case SID_COPY: // fuer Grafiken in DrawShell
{
WaitObject aWait( GetViewData()->GetDialogParent() );
pTabViewShell->CopyToClip( NULL, sal_False, sal_False, sal_True );
rReq.Done();
}
break;
case SID_CUT: // fuer Grafiken in DrawShell
{
WaitObject aWait( GetViewData()->GetDialogParent() );
pTabViewShell->CutToClip( NULL, sal_True );
rReq.Done();
}
break;
case SID_PASTE:
{
PasteFromClipboard ( GetViewData(), pTabViewShell, true );
rReq.Done();
}
break;
case SID_CLIPBOARD_FORMAT_ITEMS:
{
WaitObject aWait( GetViewData()->GetDialogParent() );
sal_uLong nFormat = 0;
const SfxPoolItem* pItem;
if ( pReqArgs &&
pReqArgs->GetItemState(nSlot, sal_True, &pItem) == SFX_ITEM_SET &&
pItem->ISA(SfxUInt32Item) )
{
nFormat = ((const SfxUInt32Item*)pItem)->GetValue();
}
if ( nFormat )
{
Window* pWin = GetViewData()->GetActiveWin();
sal_Bool bCells = ( ScTransferObj::GetOwnClipboard( pWin ) != NULL );
sal_Bool bDraw = ( ScDrawTransferObj::GetOwnClipboard( pWin ) != NULL );
sal_Bool bOle = ( nFormat == SOT_FORMATSTR_ID_EMBED_SOURCE );
if ( bCells && bOle )
pTabViewShell->PasteFromSystem();
else if ( bDraw && bOle )
pTabViewShell->PasteDraw();
else
pTabViewShell->PasteFromSystem(nFormat);
}
//?else
//? pTabViewShell->PasteFromSystem();
rReq.Done();
}
pTabViewShell->CellContentChanged();
break;
case FID_INS_CELL_CONTENTS:
{
sal_uInt16 nFlags = IDF_NONE;
sal_uInt16 nFunction = PASTE_NOFUNC;
sal_Bool bSkipEmpty = sal_False;
sal_Bool bTranspose = sal_False;
sal_Bool bAsLink = sal_False;
InsCellCmd eMoveMode = INS_NONE;
Window* pWin = GetViewData()->GetActiveWin();
ScDocument* pDoc = GetViewData()->GetDocument();
sal_Bool bOtherDoc = !pDoc->IsClipboardSource();
ScTransferObj* pOwnClip = ScTransferObj::GetOwnClipboard( pWin );
if ( pOwnClip )
{
// #129384# keep a reference in case the clipboard is changed during dialog or PasteFromClip
uno::Reference<datatransfer::XTransferable> aOwnClipRef( pOwnClip );
if ( pReqArgs!=NULL && pTabViewShell->SelectionEditable() )
{
const SfxPoolItem* pItem;
String aFlags = 'A';
if( IS_AVAILABLE( FID_INS_CELL_CONTENTS, &pItem ) )
aFlags = ((const SfxStringItem*)pItem)->GetValue();
aFlags.ToUpperAscii();
sal_Bool bCont = sal_True;
for( xub_StrLen i=0 ; bCont && i<aFlags.Len() ; i++ )
{
switch( aFlags.GetChar(i) )
{
case 'A': // Alle
nFlags |= IDF_ALL;
bCont = sal_False; // nicht mehr weitermachen!
break;
case 'S': nFlags |= IDF_STRING; break;
case 'V': nFlags |= IDF_VALUE; break;
case 'D': nFlags |= IDF_DATETIME; break;
case 'F': nFlags |= IDF_FORMULA; break;
case 'N': nFlags |= IDF_NOTE; break;
case 'T': nFlags |= IDF_ATTRIB; break;
}
}
SFX_REQUEST_ARG( rReq, pFuncItem, SfxUInt16Item, FN_PARAM_1, sal_False );
SFX_REQUEST_ARG( rReq, pSkipItem, SfxBoolItem, FN_PARAM_2, sal_False );
SFX_REQUEST_ARG( rReq, pTransposeItem, SfxBoolItem, FN_PARAM_3, sal_False );
SFX_REQUEST_ARG( rReq, pLinkItem, SfxBoolItem, FN_PARAM_4, sal_False );
SFX_REQUEST_ARG( rReq, pMoveItem, SfxInt16Item, FN_PARAM_5, sal_False );
if ( pFuncItem )
nFunction = pFuncItem->GetValue();
if ( pSkipItem )
bSkipEmpty = pSkipItem->GetValue();
if ( pTransposeItem )
bTranspose = pTransposeItem->GetValue();
if ( pLinkItem )
bAsLink = pLinkItem->GetValue();
if ( pMoveItem )
eMoveMode = (InsCellCmd) pMoveItem->GetValue();
}
else
{
ScEditableTester aTester( pTabViewShell );
if (aTester.IsEditable())
{
//CHINA001 ScInsertContentsDlg* pDlg = new ScInsertContentsDlg( pTabViewShell->GetDialogParent() );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScInsertContentsDlg* pDlg = pFact->CreateScInsertContentsDlg( pTabViewShell->GetDialogParent(),
RID_SCDLG_INSCONT);
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
pDlg->SetOtherDoc( bOtherDoc );
// #53661# bei ChangeTrack MoveMode disablen
pDlg->SetChangeTrack( pDoc->GetChangeTrack() != NULL );
// #72930# cut/move references may disable shift
// directions if source and destination ranges intersect
if ( !bOtherDoc )
{
if ( pOwnClip )
{
ScViewData* pData = GetViewData();
if ( pData->GetMarkData().GetTableSelect(
pData->GetTabNo() ) )
{
SCCOL nPosX = pData->GetCurX();
SCROW nPosY = pData->GetCurY();
SCCOL nClipStartX, nClipSizeX;
SCROW nClipStartY, nClipSizeY;
pOwnClip->GetDocument()->GetClipStart( nClipStartX, nClipStartY );
pOwnClip->GetDocument()->GetClipArea( nClipSizeX, nClipSizeY, sal_True );
int nDisableShift = 0;
if ( MAXCOL <= nPosX + nClipSizeX )
nDisableShift |= SC_CELL_SHIFT_DISABLE_RIGHT;
if ( MAXROW <= nPosY + nClipSizeY )
nDisableShift |= SC_CELL_SHIFT_DISABLE_DOWN;
if ( nDisableShift )
pDlg->SetCellShiftDisabled( nDisableShift );
}
}
}
if (pDlg->Execute() == RET_OK)
{
nFlags = pDlg->GetInsContentsCmdBits();
nFunction = pDlg->GetFormulaCmdBits();
bSkipEmpty = pDlg->IsSkipEmptyCells();
bTranspose = pDlg->IsTranspose();
bAsLink = pDlg->IsLink();
eMoveMode = pDlg->GetMoveMode();
}
delete pDlg;
}
else
pTabViewShell->ErrorMessage(aTester.GetMessageId());
}
if( nFlags != IDF_NONE )
{
{
WaitObject aWait( GetViewData()->GetDialogParent() );
if ( bAsLink && bOtherDoc )
pTabViewShell->PasteFromSystem(SOT_FORMATSTR_ID_LINK); // DDE einfuegen
else
pTabViewShell->PasteFromClip( nFlags, pOwnClip->GetDocument(),
nFunction, bSkipEmpty, bTranspose, bAsLink,
eMoveMode, IDF_NONE, sal_True ); // allow warning dialog
}
if( !pReqArgs )
{
String aFlags;
if( nFlags == IDF_ALL )
{
aFlags += 'A';
}
else
{
if( nFlags & IDF_STRING ) aFlags += 'S';
if( nFlags & IDF_VALUE ) aFlags += 'V';
if( nFlags & IDF_DATETIME ) aFlags += 'D';
if( nFlags & IDF_FORMULA ) aFlags += 'F';
if( nFlags & IDF_NOTE ) aFlags += 'N';
if( nFlags & IDF_ATTRIB ) aFlags += 'T';
}
rReq.AppendItem( SfxStringItem( FID_INS_CELL_CONTENTS, aFlags ) );
rReq.AppendItem( SfxBoolItem( FN_PARAM_2, bSkipEmpty ) );
rReq.AppendItem( SfxBoolItem( FN_PARAM_3, bTranspose ) );
rReq.AppendItem( SfxBoolItem( FN_PARAM_4, bAsLink ) );
rReq.AppendItem( SfxUInt16Item( FN_PARAM_1, nFunction ) );
rReq.AppendItem( SfxInt16Item( FN_PARAM_5, (sal_Int16) eMoveMode ) );
rReq.Done();
}
}
}
}
pTabViewShell->CellContentChanged(); // => PasteFromXXX ???
break;
case SID_PASTE_SPECIAL:
// Unterscheidung, ob eigene oder fremde Daten,
// dadurch FID_INS_CELL_CONTENTS ueberfluessig
{
Window* pWin = GetViewData()->GetActiveWin();
// Clipboard-ID als Parameter angegeben? Basic "PasteSpecial(Format)"
const SfxPoolItem* pItem=NULL;
if ( pReqArgs &&
pReqArgs->GetItemState(nSlot, sal_True, &pItem) == SFX_ITEM_SET &&
pItem->ISA(SfxUInt32Item) )
{
sal_uLong nFormat = ((const SfxUInt32Item*)pItem)->GetValue();
sal_Bool bRet=sal_True;
{
WaitObject aWait( GetViewData()->GetDialogParent() );
sal_Bool bDraw = ( ScDrawTransferObj::GetOwnClipboard( pWin ) != NULL );
if ( bDraw && nFormat == SOT_FORMATSTR_ID_EMBED_SOURCE )
pTabViewShell->PasteDraw();
else
bRet = pTabViewShell->PasteFromSystem(nFormat, sal_True); // TRUE: keine Fehlermeldungen
}
if ( bRet )
{
rReq.SetReturnValue(SfxInt16Item(nSlot, bRet)); // 1 = Erfolg, 0 = Fehler
rReq.Done();
}
else
// if format is not available -> fallback to request without parameters
pItem = NULL;
}
if ( !pItem )
{
if ( ScTransferObj::GetOwnClipboard( pWin ) ) // own cell data
{
rReq.SetSlot( FID_INS_CELL_CONTENTS );
ExecuteSlot( rReq, GetInterface() );
rReq.SetReturnValue(SfxInt16Item(nSlot, 1)); // 1 = Erfolg
}
else // Zeichenobjekte oder fremde Daten
{
sal_Bool bDraw = ( ScDrawTransferObj::GetOwnClipboard( pWin ) != NULL );
SvxClipboardFmtItem aFormats( SID_CLIPBOARD_FORMAT_ITEMS );
GetPossibleClipboardFormats( aFormats );
sal_uInt16 nFormatCount = aFormats.Count();
if ( nFormatCount )
{
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
SfxAbstractPasteDialog* pDlg = pFact->CreatePasteDialog( pTabViewShell->GetDialogParent() );
if ( pDlg )
{
for (sal_uInt16 i=0; i<nFormatCount; i++)
{
sal_uLong nFormatId = aFormats.GetClipbrdFormatId( i );
String aName = aFormats.GetClipbrdFormatName( i );
// special case for paste dialog: '*' is replaced by object type
if ( nFormatId == SOT_FORMATSTR_ID_EMBED_SOURCE )
aName.Assign((sal_Unicode)'*');
pDlg->Insert( nFormatId, aName );
}
TransferableDataHelper aDataHelper(
TransferableDataHelper::CreateFromSystemClipboard( pWin ) );
sal_uLong nFormat = pDlg->GetFormat( aDataHelper.GetTransferable() );
if (nFormat > 0)
{
{
WaitObject aWait( GetViewData()->GetDialogParent() );
if ( bDraw && nFormat == SOT_FORMATSTR_ID_EMBED_SOURCE )
pTabViewShell->PasteDraw();
else
pTabViewShell->PasteFromSystem(nFormat);
}
rReq.SetReturnValue(SfxInt16Item(nSlot, 1)); // 1 = Erfolg
rReq.AppendItem( SfxUInt32Item( nSlot, nFormat ) );
rReq.Done();
}
else
{
rReq.SetReturnValue(SfxInt16Item(nSlot, 0)); // 0 = Fehler
rReq.Ignore();
}
delete pDlg;
}
}
else
rReq.SetReturnValue(SfxInt16Item(nSlot, 0)); // 0 = Fehler
}
}
}
pTabViewShell->CellContentChanged(); // => PasteFromSystem() ???
break;
//
// sonstiges
//
case FID_INS_ROWBRK:
pTabViewShell->InsertPageBreak( sal_False );
rReq.Done();
break;
case FID_INS_COLBRK:
pTabViewShell->InsertPageBreak( sal_True );
rReq.Done();
break;
case FID_DEL_ROWBRK:
pTabViewShell->DeletePageBreak( sal_False );
rReq.Done();
break;
case FID_DEL_COLBRK:
pTabViewShell->DeletePageBreak( sal_True );
rReq.Done();
break;
case SID_DETECTIVE_ADD_PRED:
pTabViewShell->DetectiveAddPred();
rReq.Done();
break;
case SID_DETECTIVE_DEL_PRED:
pTabViewShell->DetectiveDelPred();
rReq.Done();
break;
case SID_DETECTIVE_ADD_SUCC:
pTabViewShell->DetectiveAddSucc();
rReq.Done();
break;
case SID_DETECTIVE_DEL_SUCC:
pTabViewShell->DetectiveDelSucc();
rReq.Done();
break;
case SID_DETECTIVE_ADD_ERR:
pTabViewShell->DetectiveAddError();
rReq.Done();
break;
case SID_DETECTIVE_INVALID:
pTabViewShell->DetectiveMarkInvalid();
rReq.Done();
break;
case SID_DETECTIVE_REFRESH:
pTabViewShell->DetectiveRefresh();
rReq.Done();
break;
case SID_SPELL_DIALOG:
// pTabViewShell->DoSpellingChecker();
{
SfxViewFrame* pViewFrame = pTabViewShell->GetViewFrame();
if( rReq.GetArgs() )
pViewFrame->SetChildWindow( SID_SPELL_DIALOG,
static_cast< const SfxBoolItem& >( rReq.GetArgs()->
Get( SID_SPELL_DIALOG ) ).GetValue() );
else
pViewFrame->ToggleChildWindow( SID_SPELL_DIALOG );
pViewFrame->GetBindings().Invalidate( SID_SPELL_DIALOG );
rReq.Ignore();
}
break;
case SID_HANGUL_HANJA_CONVERSION:
pTabViewShell->DoHangulHanjaConversion();
break;
case SID_CHINESE_CONVERSION:
{
//open ChineseTranslationDialog
Reference< XComponentContext > xContext(
::cppu::defaultBootstrap_InitialComponentContext() ); //@todo get context from calc if that has one
if(xContext.is())
{
Reference< lang::XMultiComponentFactory > xMCF( xContext->getServiceManager() );
if(xMCF.is())
{
Reference< ui::dialogs::XExecutableDialog > xDialog(
xMCF->createInstanceWithContext(
rtl::OUString::createFromAscii("com.sun.star.linguistic2.ChineseTranslationDialog")
, xContext), UNO_QUERY);
Reference< lang::XInitialization > xInit( xDialog, UNO_QUERY );
if( xInit.is() )
{
// initialize dialog
Reference< awt::XWindow > xDialogParentWindow(0);
Sequence<Any> aSeq(1);
Any* pArray = aSeq.getArray();
PropertyValue aParam;
aParam.Name = rtl::OUString::createFromAscii("ParentWindow");
aParam.Value <<= makeAny(xDialogParentWindow);
pArray[0] <<= makeAny(aParam);
xInit->initialize( aSeq );
//execute dialog
sal_Int16 nDialogRet = xDialog->execute();
if( RET_OK == nDialogRet )
{
//get some parameters from the dialog
sal_Bool bToSimplified = sal_True;
sal_Bool bUseVariants = sal_True;
sal_Bool bCommonTerms = sal_True;
Reference< beans::XPropertySet > xProp( xDialog, UNO_QUERY );
if( xProp.is() )
{
try
{
xProp->getPropertyValue( C2U("IsDirectionToSimplified") ) >>= bToSimplified;
xProp->getPropertyValue( C2U("IsUseCharacterVariants") ) >>= bUseVariants;
xProp->getPropertyValue( C2U("IsTranslateCommonTerms") ) >>= bCommonTerms;
}
catch( Exception& )
{
}
}
//execute translation
LanguageType eSourceLang = bToSimplified ? LANGUAGE_CHINESE_TRADITIONAL : LANGUAGE_CHINESE_SIMPLIFIED;
LanguageType eTargetLang = bToSimplified ? LANGUAGE_CHINESE_SIMPLIFIED : LANGUAGE_CHINESE_TRADITIONAL;
sal_Int32 nOptions = bUseVariants ? i18n::TextConversionOption::USE_CHARACTER_VARIANTS : 0;
if( !bCommonTerms )
nOptions |= i18n::TextConversionOption::CHARACTER_BY_CHARACTER;
Font aTargetFont = GetViewData()->GetActiveWin()->GetDefaultFont(
DEFAULTFONT_CJK_SPREADSHEET,
eTargetLang, DEFAULTFONT_FLAGS_ONLYONE );
ScConversionParam aConvParam( SC_CONVERSION_CHINESE_TRANSL,
eSourceLang, eTargetLang, aTargetFont, nOptions, false );
pTabViewShell->DoSheetConversion( aConvParam );
}
}
Reference< lang::XComponent > xComponent( xDialog, UNO_QUERY );
if( xComponent.is() )
xComponent->dispose();
}
}
}
break;
case SID_THESAURUS:
pTabViewShell->DoThesaurus();
break;
case SID_TOGGLE_REL:
pTabViewShell->DoRefConversion();
break;
case SID_DEC_INDENT:
pTabViewShell->ChangeIndent( sal_False );
break;
case SID_INC_INDENT:
pTabViewShell->ChangeIndent( sal_True );
break;
case FID_USE_NAME:
{
sal_uInt16 nFlags = pTabViewShell->GetCreateNameFlags();
//CHINA001 ScNameCreateDlg* pDlg = new ScNameCreateDlg( pTabViewShell->GetDialogParent(), nFlags );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScNameCreateDlg* pDlg = pFact->CreateScNameCreateDlg(pTabViewShell->GetDialogParent(), nFlags, RID_SCDLG_NAMES_CREATE );
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
if( pDlg->Execute() )
{
nFlags = pDlg->GetFlags();
pTabViewShell->CreateNames(nFlags);
rReq.Done();
}
delete pDlg;
}
break;
case SID_CONSOLIDATE:
{
const SfxPoolItem* pItem;
if ( pReqArgs && SFX_ITEM_SET ==
pReqArgs->GetItemState( SCITEM_CONSOLIDATEDATA, sal_True, &pItem ) )
{
const ScConsolidateParam& rParam =
((const ScConsolidateItem*)pItem)->GetData();
pTabViewShell->Consolidate( rParam );
GetViewData()->GetDocument()->SetConsolidateDlgData( &rParam );
rReq.Done();
}
else if (rReq.IsAPI())
SbxBase::SetError(SbxERR_BAD_PARAMETER);
}
break;
case SID_INS_FUNCTION:
{
const SfxBoolItem* pOkItem = (const SfxBoolItem*)&pReqArgs->Get( SID_DLG_RETOK );
// pScMod->SetFunctionDlg( NULL );
if ( pOkItem->GetValue() ) // OK
{
String aFormula;
const SfxStringItem* pSItem = (const SfxStringItem*)&pReqArgs->Get( SCITEM_STRING );
const SfxBoolItem* pMatrixItem = (const SfxBoolItem*) &pReqArgs->Get( SID_DLG_MATRIX );
aFormula += pSItem->GetValue();
pScMod->ActivateInputWindow( &aFormula, pMatrixItem->GetValue() );
}
else // CANCEL
{
pScMod->ActivateInputWindow( NULL );
}
rReq.Ignore(); // only SID_ENTER_STRING is recorded
}
break;
case FID_DEFINE_NAME:
if ( pReqArgs )
{
const SfxPoolItem* pItem;
String aName, aSymbol, aAttrib;
if( IS_AVAILABLE( FID_DEFINE_NAME, &pItem ) )
aName = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_1, &pItem ) )
aSymbol = ((const SfxStringItem*)pItem)->GetValue();
if( IS_AVAILABLE( FN_PARAM_2, &pItem ) )
aAttrib = ((const SfxStringItem*)pItem)->GetValue();
if ( aName.Len() && aSymbol.Len() )
{
if (pTabViewShell->InsertName( aName, aSymbol, aAttrib ))
rReq.Done();
else
SbxBase::SetError( SbxERR_BAD_PARAMETER ); // Basic-Fehler
}
}
else
{
sal_uInt16 nId = ScNameDlgWrapper::GetChildWindowId();
SfxViewFrame* pViewFrm = pTabViewShell->GetViewFrame();
SfxChildWindow* pWnd = pViewFrm->GetChildWindow( nId );
pScMod->SetRefDialog( nId, pWnd ? sal_False : sal_True );
}
break;
case SID_DEFINE_COLROWNAMERANGES:
{
sal_uInt16 nId = ScColRowNameRangesDlgWrapper::GetChildWindowId();
SfxViewFrame* pViewFrm = pTabViewShell->GetViewFrame();
SfxChildWindow* pWnd = pViewFrm->GetChildWindow( nId );
pScMod->SetRefDialog( nId, pWnd ? sal_False : sal_True );
}
break;
case SID_UPDATECHART:
{
sal_Bool bAll = sal_False;
if( pReqArgs )
{
const SfxPoolItem* pItem;
if( IS_AVAILABLE( SID_UPDATECHART, &pItem ) )
bAll = ((const SfxBoolItem*)pItem)->GetValue();
}
pTabViewShell->UpdateCharts( bAll );
if( ! rReq.IsAPI() )
{
rReq.AppendItem( SfxBoolItem( SID_UPDATECHART, bAll ) );
rReq.Done();
}
}
break;
case SID_TABOP:
if (pReqArgs)
{
const ScTabOpItem& rItem =
(const ScTabOpItem&)
pReqArgs->Get( SID_TABOP );
pTabViewShell->TabOp( rItem.GetData() );
rReq.Done( *pReqArgs );
}
break;
case SID_SOLVE:
if (pReqArgs)
{
const ScSolveItem& rItem =
(const ScSolveItem&)
pReqArgs->Get( SCITEM_SOLVEDATA );
pTabViewShell->Solve( rItem.GetData() );
rReq.Done( *pReqArgs );
}
break;
case FID_INSERT_NAME:
{
ScDocument* pDoc = GetViewData()->GetDocument();
//CHINA001 ScNamePasteDlg* pDlg = new ScNamePasteDlg( pTabViewShell->GetDialogParent(), pDoc->GetRangeName() );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
AbstractScNamePasteDlg* pDlg = pFact->CreateScNamePasteDlg( pTabViewShell->GetDialogParent(), pDoc->GetRangeName(), RID_SCDLG_NAMES_PASTE );
DBG_ASSERT(pDlg, "Dialog create fail!");//CHINA001
switch( pDlg->Execute() )
{
case BTN_PASTE_LIST:
pTabViewShell->InsertNameList();
break;
case BTN_PASTE_NAME:
{
ScInputHandler* pHdl = pScMod->GetInputHdl( pTabViewShell );
if (pHdl)
{
// das "=" per Key-Event, schaltet in den Eingabe-Modus
pScMod->InputKeyEvent( KeyEvent('=',KeyCode()) );
String aName = pDlg->GetSelectedName();
pHdl->InsertFunction( aName, sal_False ); // ohne "()"
}
}
break;
}
delete pDlg;
}
break;
case SID_RANGE_NOTETEXT:
if (pReqArgs)
{
const SfxStringItem& rTextItem = (const SfxStringItem&)pReqArgs->Get( SID_RANGE_NOTETEXT );
// #43343# immer Cursorposition
ScAddress aPos( GetViewData()->GetCurX(), GetViewData()->GetCurY(), GetViewData()->GetTabNo() );
pTabViewShell->SetNoteText( aPos, rTextItem.GetValue() );
rReq.Done();
}
break;
case SID_INSERT_POSTIT:
if ( pReqArgs )
{
const SvxPostItAuthorItem& rAuthorItem = (const SvxPostItAuthorItem&)pReqArgs->Get( SID_ATTR_POSTIT_AUTHOR );
const SvxPostItDateItem& rDateItem = (const SvxPostItDateItem&) pReqArgs->Get( SID_ATTR_POSTIT_DATE );
const SvxPostItTextItem& rTextItem = (const SvxPostItTextItem&) pReqArgs->Get( SID_ATTR_POSTIT_TEXT );
ScAddress aPos( GetViewData()->GetCurX(), GetViewData()->GetCurY(), GetViewData()->GetTabNo() );
pTabViewShell->ReplaceNote( aPos, rTextItem.GetValue(), &rAuthorItem.GetValue(), &rDateItem.GetValue() );
rReq.Done();
}
else
{
pTabViewShell->EditNote(); // Zeichenobjekt zum Editieren
}
break;
case FID_NOTE_VISIBLE:
{
ScDocument* pDoc = GetViewData()->GetDocument();
ScAddress aPos( GetViewData()->GetCurX(), GetViewData()->GetCurY(), GetViewData()->GetTabNo() );
if( ScPostIt* pNote = pDoc->GetNote( aPos ) )
{
bool bShow;
const SfxPoolItem* pItem;
if ( pReqArgs && (pReqArgs->GetItemState( FID_NOTE_VISIBLE, sal_True, &pItem ) == SFX_ITEM_SET) )
bShow = ((const SfxBoolItem*) pItem)->GetValue();
else
bShow = !pNote->IsCaptionShown();
pTabViewShell->ShowNote( bShow );
if (!pReqArgs)
rReq.AppendItem( SfxBoolItem( FID_NOTE_VISIBLE, bShow ) );
rReq.Done();
rBindings.Invalidate( FID_NOTE_VISIBLE );
}
else
rReq.Ignore();
}
break;
case SID_DELETE_NOTE:
pTabViewShell->DeleteContents( IDF_NOTE ); // delete all notes in selection
rReq.Done();
break;
case SID_CHARMAP:
if( pReqArgs != NULL )
{
String aChars, aFontName;
const SfxItemSet *pArgs = rReq.GetArgs();
const SfxPoolItem* pItem = 0;
if ( pArgs )
pArgs->GetItemState(GetPool().GetWhich(SID_CHARMAP), sal_False, &pItem);
if ( pItem )
{
const SfxStringItem* pStringItem = PTR_CAST( SfxStringItem, pItem );
if ( pStringItem )
aChars = pStringItem->GetValue();
const SfxPoolItem* pFtItem = NULL;
pArgs->GetItemState( GetPool().GetWhich(SID_ATTR_SPECIALCHAR), sal_False, &pFtItem);
const SfxStringItem* pFontItem = PTR_CAST( SfxStringItem, pFtItem );
if ( pFontItem )
aFontName = pFontItem->GetValue();
}
if ( aChars.Len() )
{
Font aFont;
pTabViewShell->GetSelectionPattern()->GetFont( aFont, SC_AUTOCOL_BLACK, NULL, NULL, NULL,
pTabViewShell->GetSelectionScriptType() );
if ( aFontName.Len() )
aFont = Font( aFontName, Size(1,1) );
pTabViewShell->InsertSpecialChar( aChars, aFont );
if( ! rReq.IsAPI() )
rReq.Done();
}
}
else
{
//CHINA001 SvxCharacterMap* pDlg = new SvxCharacterMap( pTabViewShell->GetDialogParent(), sal_False );
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
// font color doesn't matter here
Font aCurFont;
pTabViewShell->GetSelectionPattern()->GetFont( aCurFont, SC_AUTOCOL_BLACK, NULL, NULL, NULL,
pTabViewShell->GetSelectionScriptType() );
SfxAllItemSet aSet( GetPool() );
aSet.Put( SfxBoolItem( FN_PARAM_1, sal_False ) );
aSet.Put( SvxFontItem( aCurFont.GetFamily(), aCurFont.GetName(), aCurFont.GetStyleName(), aCurFont.GetPitch(), aCurFont.GetCharSet(), GetPool().GetWhich(SID_ATTR_CHAR_FONT) ) );
SfxAbstractDialog* pDlg = pFact->CreateSfxDialog( pTabViewShell->GetDialogParent(), aSet,
pTabViewShell->GetViewFrame()->GetFrame().GetFrameInterface(), RID_SVXDLG_CHARMAP );
if ( pDlg->Execute() == RET_OK )
{
SFX_ITEMSET_ARG( pDlg->GetOutputItemSet(), pItem, SfxStringItem, SID_CHARMAP, sal_False );
SFX_ITEMSET_ARG( pDlg->GetOutputItemSet(), pFontItem, SvxFontItem, SID_ATTR_CHAR_FONT, sal_False );
if ( pItem && pFontItem )
{
Font aNewFont( pFontItem->GetFamilyName(), pFontItem->GetStyleName(), Size(1,1) );
aNewFont.SetCharSet( pFontItem->GetCharSet() );
aNewFont.SetPitch( pFontItem->GetPitch() );
pTabViewShell->InsertSpecialChar( pItem->GetValue(), aNewFont );
rReq.AppendItem( *pFontItem );
rReq.AppendItem( *pItem );
rReq.Done();
}
}
delete pDlg;
}
break;
case SID_SELECT_SCENARIO:
{
// Testing
if ( pReqArgs )
{
const SfxStringItem* pItem =
(const SfxStringItem*)&pReqArgs->Get( SID_SELECT_SCENARIO );
if( pItem )
{
pTabViewShell->UseScenario( pItem->GetValue() );
//! wofuer soll der Return-Wert gut sein?!?!
rReq.SetReturnValue( SfxStringItem( SID_SELECT_SCENARIO, pItem->GetValue() ) );
rReq.Done();
}
else
{
DBG_ERROR("NULL");
}
}
}
break;
case SID_HYPERLINK_SETLINK:
if( pReqArgs )
{
const SfxPoolItem* pItem;
if( IS_AVAILABLE( SID_HYPERLINK_SETLINK, &pItem ) )
{
const SvxHyperlinkItem* pHyper = (const SvxHyperlinkItem*) pItem;
const String& rName = pHyper->GetName();
const String& rURL = pHyper->GetURL();
const String& rTarget = pHyper->GetTargetFrame();
sal_uInt16 nType = (sal_uInt16) pHyper->GetInsertMode();
pTabViewShell->InsertURL( rName, rURL, rTarget, nType );
rReq.Done();
}
else
rReq.Ignore();
}
break;
case FID_CONDITIONAL_FORMAT:
if( pReqArgs )
{
const SfxPoolItem* pItem;
if( IS_AVAILABLE( FID_CONDITIONAL_FORMAT, &pItem ) )
{
// Wenn RefInput auf andere Tabelle als Datentabelle umgeschaltet
// hat wieder zurueckschalten:
if ( GetViewData()->GetTabNo() != GetViewData()->GetRefTabNo() )
{
pTabViewShell->SetTabNo( GetViewData()->GetRefTabNo() );
pTabViewShell->PaintExtras();
}
const ScCondFrmtItem* pCndFmtItem = (const ScCondFrmtItem*) pItem;
pTabViewShell->SetConditionalFormat( pCndFmtItem->GetData() );
rReq.Done();
}
}
break;
case SID_EXTERNAL_SOURCE:
{
String aFile;
String aFilter;
String aOptions;
String aSource;
sal_uLong nRefresh=0;
SFX_REQUEST_ARG( rReq, pFile, SfxStringItem, SID_FILE_NAME, sal_False );
SFX_REQUEST_ARG( rReq, pSource, SfxStringItem, FN_PARAM_1, sal_False );
if ( pFile && pSource )
{
aFile = pFile->GetValue();
aSource = pSource->GetValue();
SFX_REQUEST_ARG( rReq, pFilter, SfxStringItem, SID_FILTER_NAME, sal_False );
if ( pFilter )
aFilter = pFilter->GetValue();
SFX_REQUEST_ARG( rReq, pOptions, SfxStringItem, SID_FILE_FILTEROPTIONS, sal_False );
if ( pOptions )
aOptions = pOptions->GetValue();
SFX_REQUEST_ARG( rReq, pRefresh, SfxUInt32Item, FN_PARAM_2, sal_False );
if ( pRefresh )
nRefresh = pRefresh->GetValue();
}
else
{
//CHINA001 ScLinkedAreaDlg* pDlg = new ScLinkedAreaDlg( pTabViewShell->GetDialogParent() );
ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
DBG_ASSERT(pFact, "ScAbstractFactory create fail!");//CHINA001
delete pImpl->m_pLinkedDlg;
pImpl->m_pLinkedDlg =
pFact->CreateScLinkedAreaDlg( pTabViewShell->GetDialogParent(),
RID_SCDLG_LINKAREA);
DBG_ASSERT(pImpl->m_pLinkedDlg, "Dialog create fail!");//CHINA001
delete pImpl->m_pRequest;
pImpl->m_pRequest = new SfxRequest( rReq );
pImpl->m_pLinkedDlg->StartExecuteModal( LINK( this, ScCellShell, DialogClosed ) );
return;
}
ExecuteExternalSource( aFile, aFilter, aOptions, aSource, nRefresh, rReq );
}
break;
//
//
//
default:
DBG_ERROR("falscher Slot bei ExecuteEdit");
break;
}
}
void ScCellShell::ExecuteTrans( SfxRequest& rReq )
{
sal_Int32 nType = ScViewUtil::GetTransliterationType( rReq.GetSlot() );
if ( nType )
{
GetViewData()->GetView()->TransliterateText( nType );
rReq.Done();
}
}
void ScCellShell::ExecuteExternalSource(
const String& _rFile, const String& _rFilter, const String& _rOptions,
const String& _rSource, sal_uLong _nRefresh, SfxRequest& _rRequest )
{
if ( _rFile.Len() && _rSource.Len() ) // filter may be empty
{
ScRange aLinkRange;
sal_Bool bMove = sal_False;
ScViewData* pData = GetViewData();
ScMarkData& rMark = pData->GetMarkData();
rMark.MarkToSimple();
if ( rMark.IsMarked() )
{
rMark.GetMarkArea( aLinkRange );
bMove = sal_True; // insert/delete cells to fit range
}
else
aLinkRange = ScRange( pData->GetCurX(), pData->GetCurY(), pData->GetTabNo() );
ScDocFunc aFunc(*pData->GetDocShell());
aFunc.InsertAreaLink( _rFile, _rFilter, _rOptions, _rSource,
aLinkRange, _nRefresh, bMove, sal_False );
_rRequest.Done();
}
else
_rRequest.Ignore();
}
IMPL_LINK( ScCellShell, DialogClosed, AbstractScLinkedAreaDlg*, EMPTYARG )
{
DBG_ASSERT( pImpl->m_pLinkedDlg, "ScCellShell::DialogClosed(): invalid request" );
DBG_ASSERT( pImpl->m_pRequest, "ScCellShell::DialogClosed(): invalid request" );
String sFile, sFilter, sOptions, sSource;
sal_uLong nRefresh = 0;
if ( pImpl->m_pLinkedDlg->GetResult() == RET_OK )
{
sFile = pImpl->m_pLinkedDlg->GetURL();
sFilter = pImpl->m_pLinkedDlg->GetFilter();
sOptions = pImpl->m_pLinkedDlg->GetOptions();
sSource = pImpl->m_pLinkedDlg->GetSource();
nRefresh = pImpl->m_pLinkedDlg->GetRefresh();
if ( sFile.Len() )
pImpl->m_pRequest->AppendItem( SfxStringItem( SID_FILE_NAME, sFile ) );
if ( sFilter.Len() )
pImpl->m_pRequest->AppendItem( SfxStringItem( SID_FILTER_NAME, sFilter ) );
if ( sOptions.Len() )
pImpl->m_pRequest->AppendItem( SfxStringItem( SID_FILE_FILTEROPTIONS, sOptions ) );
if ( sSource.Len() )
pImpl->m_pRequest->AppendItem( SfxStringItem( FN_PARAM_1, sSource ) );
if ( nRefresh )
pImpl->m_pRequest->AppendItem( SfxUInt32Item( FN_PARAM_2, nRefresh ) );
}
ExecuteExternalSource( sFile, sFilter, sOptions, sSource, nRefresh, *(pImpl->m_pRequest) );
return 0;
}
void ScCellShell::PasteFromClipboard( ScViewData* pViewData, ScTabViewShell* pTabViewShell, bool bShowDialog )
{
Window* pWin = pViewData->GetActiveWin();
ScTransferObj* pOwnClip = ScTransferObj::GetOwnClipboard( pWin );
ScDocument* pThisDoc = pViewData->GetDocument();
ScDPObject* pDPObj = pThisDoc->GetDPAtCursor( pViewData->GetCurX(),
pViewData->GetCurY(), pViewData->GetTabNo() );
if ( pOwnClip && pDPObj )
{
// paste from Calc into DataPilot table: sort (similar to drag & drop)
ScDocument* pClipDoc = pOwnClip->GetDocument();
SCTAB nSourceTab = pOwnClip->GetVisibleTab();
SCCOL nClipStartX;
SCROW nClipStartY;
SCCOL nClipEndX;
SCROW nClipEndY;
pClipDoc->GetClipStart( nClipStartX, nClipStartY );
pClipDoc->GetClipArea( nClipEndX, nClipEndY, sal_True );
nClipEndX = nClipEndX + nClipStartX;
nClipEndY = nClipEndY + nClipStartY; // GetClipArea returns the difference
ScRange aSource( nClipStartX, nClipStartY, nSourceTab, nClipEndX, nClipEndY, nSourceTab );
sal_Bool bDone = pTabViewShell->DataPilotMove( aSource, pViewData->GetCurPos() );
if ( !bDone )
pTabViewShell->ErrorMessage( STR_ERR_DATAPILOT_INPUT );
}
else
{
// normal paste
WaitObject aWait( pViewData->GetDialogParent() );
if (!pOwnClip)
pTabViewShell->PasteFromSystem();
else
{
ScDocument* pClipDoc = pOwnClip->GetDocument();
sal_uInt16 nFlags = IDF_ALL;
if (pClipDoc->GetClipParam().isMultiRange())
// For multi-range paste, we paste values by default.
nFlags &= ~IDF_FORMULA;
pTabViewShell->PasteFromClip( nFlags, pClipDoc,
PASTE_NOFUNC, sal_False, sal_False, sal_False, INS_NONE, IDF_NONE,
bShowDialog ); // allow warning dialog
}
}
pTabViewShell->CellContentChanged(); // => PasteFromSystem() ???
}