2000-09-18 16:15:01 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* $RCSfile: tabsh.cxx,v $
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-11-04 15:02:31 +00:00
|
|
|
* $Revision: 1.35 $
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-11-04 15:02:31 +00:00
|
|
|
* last change: $Author: kz $ $Date: 2005-11-04 16:02:31 $
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* The Contents of this file are made available subject to
|
|
|
|
* the terms of GNU Lesser General Public License Version 2.1.
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2005 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
2005-09-09 09:53:09 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
* MA 02111-1307 USA
|
2000-09-18 16:15:01 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
#pragma hdrstop
|
|
|
|
|
|
|
|
#ifndef _UIPARAM_HXX
|
|
|
|
#include <uiparam.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _HINTIDS_HXX
|
|
|
|
#include <hintids.hxx>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _ZFORLIST_HXX
|
|
|
|
#define _ZFORLIST_DECLARE_TABLE
|
|
|
|
#include <svtools/zforlist.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFXSTRITEM_HXX //autogen
|
|
|
|
#include <svtools/stritem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFX_WHITER_HXX //autogen
|
|
|
|
#include <svtools/whiter.hxx>
|
|
|
|
#endif
|
2000-11-14 17:32:27 +00:00
|
|
|
#ifndef INCLUDED_SVTOOLS_MODULEOPTIONS_HXX
|
|
|
|
#include <svtools/moduleoptions.hxx>
|
|
|
|
#endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _SVX_RULRITEM_HXX //autogen
|
|
|
|
#include <svx/rulritem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_SRCHITEM_HXX
|
|
|
|
#include <svx/srchitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_LRSPITEM_HXX //autogen
|
|
|
|
#include <svx/lrspitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_ULSPITEM_HXX //autogen
|
|
|
|
#include <svx/ulspitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_BRSHITEM_HXX //autogen
|
|
|
|
#include <svx/brshitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_BOXITEM_HXX //autogen
|
|
|
|
#include <svx/boxitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_SHADITEM_HXX //autogen
|
|
|
|
#include <svx/shaditem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_SPLTITEM_HXX //autogen
|
|
|
|
#include <svx/spltitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_LANGITEM_HXX //autogen
|
|
|
|
#include <svx/langitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_KEEPITEM_HXX //autogen
|
|
|
|
#include <svx/keepitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_BOLNITEM_HXX //autogen
|
|
|
|
#include <svx/bolnitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_COLRITEM_HXX //autogen
|
|
|
|
#include <svx/colritem.hxx>
|
|
|
|
#endif
|
2002-06-17 10:11:16 +00:00
|
|
|
#ifndef _SVX_FRMDIRITEM_HXX
|
|
|
|
#include <svx/frmdiritem.hxx>
|
|
|
|
#endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _SVX_NUMINF_HXX //autogen
|
|
|
|
#include <svx/numinf.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ZFORMAT_HXX //autogen
|
|
|
|
#include <svtools/zformat.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFX_BINDINGS_HXX //autogen
|
|
|
|
#include <sfx2/bindings.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _MSGBOX_HXX //autogen
|
|
|
|
#include <vcl/msgbox.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFXREQUEST_HXX //autogen
|
|
|
|
#include <sfx2/request.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFXDISPATCH_HXX //autogen
|
|
|
|
#include <sfx2/dispatch.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFXOBJFACE_HXX //autogen
|
|
|
|
#include <sfx2/objface.hxx>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef _FMTORNT_HXX //autogen
|
|
|
|
#include <fmtornt.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTCLDS_HXX //autogen
|
|
|
|
#include <fmtclds.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTTSPLT_HXX //autogen
|
|
|
|
#include <fmtlsplt.hxx>
|
|
|
|
#endif
|
2004-01-13 10:27:07 +00:00
|
|
|
#ifndef _FMTROWSPLT_HXX //autogen
|
|
|
|
#include <fmtrowsplt.hxx>
|
|
|
|
#endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _FMTFSIZE_HXX //autogen
|
|
|
|
#include <fmtfsize.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SWMODULE_HXX
|
|
|
|
#include <swmodule.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _WRTSH_HXX
|
|
|
|
#include <wrtsh.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _WVIEW_HXX
|
|
|
|
#include <wview.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FRMATR_HXX
|
|
|
|
#include <frmatr.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _UITOOL_HXX
|
|
|
|
#include <uitool.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _INPUTWIN_HXX
|
|
|
|
#include <inputwin.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _UIITEMS_HXX
|
|
|
|
#include <uiitems.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _USRPREF_HXX
|
|
|
|
#include <usrpref.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TABSH_HXX
|
|
|
|
#include <tabsh.hxx>
|
|
|
|
#endif
|
2004-05-10 15:35:51 +00:00
|
|
|
#ifndef _SWTABLEREP_HXX
|
|
|
|
#include "swtablerep.hxx" //CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _TABLEMGR_HXX
|
|
|
|
#include <tablemgr.hxx>
|
|
|
|
#endif
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 #ifndef _TAUTOFMT_HXX
|
|
|
|
//CHINA001 #include <tautofmt.hxx>
|
|
|
|
//CHINA001 #endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _CELLATR_HXX
|
|
|
|
#include <cellatr.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FRMFMT_HXX
|
|
|
|
#include <frmfmt.hxx>
|
|
|
|
#endif
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 #ifndef _ROWHT_HXX
|
|
|
|
//CHINA001 #include <rowht.hxx>
|
|
|
|
//CHINA001 #endif
|
|
|
|
//CHINA001 #ifndef _SPLIT_HXX
|
|
|
|
//CHINA001 #include <split.hxx>
|
|
|
|
//CHINA001 #endif
|
|
|
|
//CHINA001 #ifndef _INSRC_HXX
|
|
|
|
//CHINA001 #include <insrc.hxx>
|
|
|
|
//CHINA001 #endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _SWUNDO_HXX
|
|
|
|
#include <swundo.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SWTABLE_HXX
|
|
|
|
#include <swtable.hxx>
|
|
|
|
#endif
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 #ifndef _TBLNUMFM_HXX
|
|
|
|
//CHINA001 #include <tblnumfm.hxx>
|
|
|
|
//CHINA001 #endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _DOCSH_HXX
|
|
|
|
#include <docsh.hxx>
|
|
|
|
#endif
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 #ifndef _SPLITTBL_HXX
|
|
|
|
//CHINA001 #include <splittbl.hxx>
|
|
|
|
//CHINA001 #endif
|
|
|
|
//CHINA001 #ifndef _MERGETBL_HXX
|
|
|
|
//CHINA001 #include <mergetbl.hxx>
|
|
|
|
//CHINA001 #endif
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _TBLSEL_HXX
|
|
|
|
#include <tblsel.hxx>
|
|
|
|
#endif
|
|
|
|
|
2004-06-01 06:46:15 +00:00
|
|
|
//!!! new: insert table
|
|
|
|
/*
|
|
|
|
#ifndef _SVX_HTMLMODE_HXX
|
|
|
|
#include <svx/htmlmode.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _MODOPT_HXX //autogen
|
|
|
|
#include <modcfg.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TBLAFMT_HXX
|
|
|
|
#include <tblafmt.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _INSTABLE_HXX
|
|
|
|
#include <instable.hxx>
|
|
|
|
#endif
|
|
|
|
*/
|
|
|
|
//!!!
|
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
#ifndef _POPUP_HRC
|
|
|
|
#include <popup.hrc>
|
|
|
|
#endif
|
|
|
|
#ifndef _SHELLS_HRC
|
|
|
|
#include <shells.hrc>
|
|
|
|
#endif
|
|
|
|
#ifndef _TABLE_HRC
|
|
|
|
#include <table.hrc>
|
|
|
|
#endif
|
|
|
|
#ifndef _CMDID_H
|
|
|
|
#include <cmdid.h>
|
|
|
|
#endif
|
|
|
|
#ifndef _GLOBALS_HRC
|
|
|
|
#include <globals.hrc>
|
|
|
|
#endif
|
|
|
|
#ifndef _HELPID_H
|
|
|
|
#include <helpid.h>
|
|
|
|
#endif
|
2003-04-17 09:16:29 +00:00
|
|
|
#ifndef _UNOOBJ_HXX
|
|
|
|
#include <unoobj.hxx>
|
|
|
|
#endif
|
2000-09-18 16:15:01 +00:00
|
|
|
|
|
|
|
#define SwTableShell
|
|
|
|
#ifndef _ITEMDEF_HXX
|
|
|
|
#include <itemdef.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SWSLOTS_HXX
|
|
|
|
#include <swslots.hxx>
|
|
|
|
#endif
|
2004-08-23 08:08:29 +00:00
|
|
|
|
2004-05-10 15:35:51 +00:00
|
|
|
#include "swabstdlg.hxx" //CHINA001
|
|
|
|
#include "dialog.hrc" //CHINA001
|
|
|
|
#include <table.hrc> //CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
BOOL lcl_IsNumeric(const String& rStr)
|
|
|
|
{
|
|
|
|
for(xub_StrLen i = 0; i < rStr.Len(); i++)
|
|
|
|
{
|
|
|
|
sal_Unicode c = rStr.GetChar(i);
|
|
|
|
if((c < '0') || (c > '9'))
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
SFX_IMPL_INTERFACE(SwTableShell, SwBaseShell, SW_RES(STR_SHELLNAME_TABLE))
|
|
|
|
{
|
|
|
|
SFX_POPUPMENU_REGISTRATION(SW_RES(MN_TAB_POPUPMENU));
|
|
|
|
SFX_OBJECTBAR_REGISTRATION(SFX_OBJECTBAR_OBJECT, SW_RES(RID_TABLE_TOOLBOX));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TYPEINIT1(SwTableShell,SwBaseShell)
|
|
|
|
|
|
|
|
/************************************************************************/
|
|
|
|
|
2004-08-23 08:08:29 +00:00
|
|
|
const USHORT __FAR_DATA aUITableAttrRange[] =
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
|
|
|
FN_PARAM_TABLE_NAME, FN_PARAM_TABLE_NAME,
|
|
|
|
FN_PARAM_TABLE_HEADLINE, FN_PARAM_TABLE_HEADLINE,
|
|
|
|
FN_PARAM_TABLE_SPACE, FN_PARAM_TABLE_SPACE,
|
|
|
|
FN_TABLE_REP, FN_TABLE_REP,
|
|
|
|
SID_RULER_BORDERS, SID_RULER_BORDERS,
|
|
|
|
RES_LR_SPACE, RES_UL_SPACE,
|
|
|
|
SID_ATTR_BORDER_INNER, SID_ATTR_BORDER_SHADOW,
|
|
|
|
RES_BOX, RES_SHADOW,
|
|
|
|
RES_BACKGROUND, RES_BACKGROUND,
|
|
|
|
SID_BACKGRND_DESTINATION, SID_BACKGRND_DESTINATION,
|
|
|
|
SID_HTML_MODE, SID_HTML_MODE,
|
|
|
|
SID_ATTR_BRUSH_ROW, SID_ATTR_BRUSH_TABLE,
|
|
|
|
RES_PAGEDESC, RES_BREAK,
|
|
|
|
RES_KEEP, RES_KEEP,
|
|
|
|
RES_LAYOUT_SPLIT, RES_LAYOUT_SPLIT,
|
|
|
|
FN_TABLE_SET_VERT_ALIGN, FN_TABLE_SET_VERT_ALIGN,
|
2002-06-17 10:11:16 +00:00
|
|
|
RES_FRAMEDIR, RES_FRAMEDIR,
|
2004-01-13 10:27:07 +00:00
|
|
|
RES_ROW_SPLIT, RES_ROW_SPLIT,
|
2004-04-21 09:00:22 +00:00
|
|
|
FN_TABLE_BOX_TEXTDIRECTION, FN_TABLE_BOX_TEXTDIRECTION,
|
2004-07-12 12:37:44 +00:00
|
|
|
// --> collapsing borders FME 2005-05-27 #i29550#
|
|
|
|
RES_COLLAPSING_BORDERS, RES_COLLAPSING_BORDERS,
|
|
|
|
// <-- collapsing borders
|
2000-09-18 16:15:01 +00:00
|
|
|
0
|
|
|
|
};
|
|
|
|
|
2004-08-23 08:08:29 +00:00
|
|
|
const USHORT* SwuiGetUITableAttrRange()
|
|
|
|
{
|
|
|
|
return aUITableAttrRange;
|
|
|
|
}
|
2000-09-18 16:15:01 +00:00
|
|
|
|
2004-08-23 08:08:29 +00:00
|
|
|
static void lcl_SetAttr( SwWrtShell &rSh, const SfxPoolItem &rItem )
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
|
|
|
SfxItemSet aSet( rSh.GetView().GetPool(), rItem.Which(), rItem.Which(), 0);
|
|
|
|
aSet.Put( rItem );
|
|
|
|
rSh.SetTblAttr( aSet );
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************/
|
|
|
|
|
|
|
|
|
2004-08-23 08:08:29 +00:00
|
|
|
static SwTableRep* lcl_TableParamToItemSet( SfxItemSet& rSet, SwWrtShell &rSh )
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
|
|
|
SwFrmFmt *pFmt = rSh.GetTableFmt();
|
|
|
|
SwTabCols aCols;
|
|
|
|
rSh.GetTabCols( aCols );
|
|
|
|
|
|
|
|
//Ersteinmal die einfachen Attribute besorgen.
|
|
|
|
rSet.Put( SfxStringItem( FN_PARAM_TABLE_NAME, pFmt->GetName()));
|
2004-05-03 12:54:38 +00:00
|
|
|
rSet.Put( SfxUInt16Item( FN_PARAM_TABLE_HEADLINE, rSh.GetRowsToRepeat() ) );
|
2000-09-18 16:15:01 +00:00
|
|
|
rSet.Put( pFmt->GetShadow() );
|
|
|
|
rSet.Put(SfxUInt16Item(FN_TABLE_SET_VERT_ALIGN, rSh.GetBoxAlign()));
|
2002-06-17 10:11:16 +00:00
|
|
|
rSet.Put( pFmt->GetFrmDir() );
|
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
SvxULSpaceItem aULSpace( pFmt->GetULSpace() );
|
|
|
|
rSet.Put( aULSpace );
|
|
|
|
|
|
|
|
USHORT nBackgroundDestination = rSh.GetViewOptions()->GetTblDest();
|
|
|
|
rSet.Put(SwBackgroundDestinationItem(SID_BACKGRND_DESTINATION, nBackgroundDestination ));
|
|
|
|
SvxBrushItem aBrush( RES_BACKGROUND );
|
|
|
|
// rSh.GetBoxBackground(aBrush);
|
|
|
|
// rSet.Put( aBrush );
|
2001-10-31 07:42:52 +00:00
|
|
|
if(rSh.GetRowBackground(aBrush))
|
|
|
|
rSet.Put( aBrush, SID_ATTR_BRUSH_ROW );
|
|
|
|
else
|
|
|
|
rSet.InvalidateItem(SID_ATTR_BRUSH_ROW);
|
|
|
|
rSh.GetTabBackground(aBrush);
|
2000-09-18 16:15:01 +00:00
|
|
|
rSet.Put( aBrush, SID_ATTR_BRUSH_TABLE );
|
2004-04-21 09:00:22 +00:00
|
|
|
|
|
|
|
// text direction in boxes
|
|
|
|
SvxFrameDirectionItem aBoxDirection;
|
|
|
|
if(rSh.GetBoxDirection( aBoxDirection ))
|
|
|
|
rSet.Put(aBoxDirection, FN_TABLE_BOX_TEXTDIRECTION);
|
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
FASTBOOL bTableSel = rSh.IsTableMode();
|
|
|
|
if(!bTableSel)
|
|
|
|
{
|
|
|
|
rSh.StartAllAction();
|
|
|
|
rSh.Push();
|
|
|
|
rSh.GetView().GetViewFrame()->GetDispatcher()->Execute( FN_TABLE_SELECT_ALL, FALSE );
|
|
|
|
}
|
|
|
|
SvxBoxInfoItem aBoxInfo;
|
|
|
|
|
|
|
|
// Tabellenvariante, wenn mehrere Tabellenzellen selektiert
|
|
|
|
rSh.GetCrsr(); //Damit GetCrsrCnt() auch das Richtige liefert
|
|
|
|
aBoxInfo.SetTable (rSh.IsTableMode() && rSh.GetCrsrCnt() > 1 ||
|
|
|
|
!bTableSel);
|
|
|
|
// Abstandsfeld immer anzeigen
|
|
|
|
aBoxInfo.SetDist ((BOOL) TRUE);
|
|
|
|
// Minimalgroesse in Tabellen und Absaetzen setzen
|
|
|
|
aBoxInfo.SetMinDist( !bTableSel || rSh.IsTableMode() ||
|
|
|
|
rSh.GetSelectionType() &
|
|
|
|
(SwWrtShell::SEL_TXT | SwWrtShell::SEL_TBL));
|
|
|
|
// Default-Abstand immer setzen
|
|
|
|
aBoxInfo.SetDefDist (MIN_BORDER_DIST);
|
|
|
|
// Einzelne Linien koennen nur in Tabellen DontCare-Status haben
|
|
|
|
aBoxInfo.SetValid( VALID_DISABLE, !bTableSel || !rSh.IsTableMode() );
|
|
|
|
|
|
|
|
rSet.Put(aBoxInfo);
|
|
|
|
rSh.GetTabBorders( rSet );
|
|
|
|
|
2004-01-13 10:27:07 +00:00
|
|
|
//row split
|
|
|
|
SwFmtRowSplit* pSplit = 0;
|
|
|
|
rSh.GetRowSplit(pSplit);
|
|
|
|
if(pSplit)
|
|
|
|
{
|
|
|
|
rSet.Put(*pSplit);
|
|
|
|
delete pSplit;
|
|
|
|
}
|
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
if(!bTableSel)
|
|
|
|
{
|
|
|
|
rSh.ClearMark();
|
|
|
|
rSh.Pop(FALSE);
|
|
|
|
rSh.EndAllAction();
|
|
|
|
}
|
|
|
|
|
|
|
|
SwTabCols aTabCols;
|
|
|
|
rSh.GetTabCols( aTabCols );
|
|
|
|
SvxColumnItem aColItem;
|
|
|
|
|
|
|
|
|
|
|
|
// Pointer wird nach der Dialogausfuehrung geloescht
|
|
|
|
SwTableRep* pRep = new SwTableRep( aTabCols, rSh.IsTblComplex());
|
|
|
|
pRep->SetSpace(aCols.GetRightMax());
|
|
|
|
|
|
|
|
USHORT nPercent = 0;
|
|
|
|
long nWidth = ::GetTableWidth(pFmt, aCols, &nPercent, &rSh );
|
|
|
|
// Die Tabellenbreite ist fuer relative Angaben nicht korrekt
|
|
|
|
if(nPercent)
|
|
|
|
nWidth = pRep->GetSpace() * nPercent / 100;
|
|
|
|
USHORT nAlign = pFmt->GetHoriOrient().GetHoriOrient();
|
|
|
|
pRep->SetAlign(nAlign);
|
|
|
|
SvxLRSpaceItem aLRSpace( pFmt->GetLRSpace() );
|
|
|
|
SwTwips nLeft = aLRSpace.GetLeft();
|
|
|
|
SwTwips nRight = aLRSpace.GetRight();
|
|
|
|
SwTwips nDiff = pRep->GetSpace() - nRight - nLeft - nWidth;
|
|
|
|
if(nAlign != HORI_FULL && Abs(nDiff) > 2)
|
|
|
|
{
|
|
|
|
SwTwips nLR = pRep->GetSpace() - nWidth;
|
|
|
|
switch ( nAlign )
|
|
|
|
{
|
|
|
|
case HORI_CENTER: nLeft = nRight = nLR / 2;
|
|
|
|
break;
|
|
|
|
case HORI_LEFT: nRight = nLR; nLeft = 0;
|
|
|
|
break;
|
|
|
|
case HORI_RIGHT: nLeft = nLR, nRight = 0;
|
|
|
|
break;
|
|
|
|
case HORI_LEFT_AND_WIDTH:
|
|
|
|
nRight = nLR - nLeft;
|
|
|
|
break;
|
|
|
|
case HORI_NONE:
|
|
|
|
if(!nPercent)
|
|
|
|
nWidth = pRep->GetSpace() - nLeft - nRight;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
pRep->SetLeftSpace(nLeft);
|
|
|
|
pRep->SetRightSpace(nRight);
|
|
|
|
|
|
|
|
pRep->SetWidth(nWidth);
|
|
|
|
pRep->SetWidthPercent(nPercent);
|
|
|
|
// sind einzelne Zeilen/Zellen selektiert, wird die Spaltenbearbeitung veraendert
|
|
|
|
pRep->SetLineSelected(bTableSel && ! rSh.HasWholeTabSelection());
|
|
|
|
rSet.Put(SwPtrItem(FN_TABLE_REP, pRep));
|
|
|
|
return pRep;
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************/
|
|
|
|
|
|
|
|
|
2004-08-23 08:08:29 +00:00
|
|
|
void ItemSetToTableParam( const SfxItemSet& rSet,
|
2000-09-18 16:15:01 +00:00
|
|
|
SwWrtShell &rSh )
|
|
|
|
{
|
|
|
|
rSh.StartAllAction();
|
|
|
|
rSh.StartUndo( UNDO_TABLE_ATTR );
|
|
|
|
const SfxPoolItem* pItem = 0;
|
|
|
|
|
|
|
|
SwViewOption aUsrPref( *rSh.GetViewOptions() );
|
|
|
|
USHORT nBackgroundDestination = aUsrPref.GetTblDest();
|
|
|
|
if(SFX_ITEM_SET == rSet.GetItemState(SID_BACKGRND_DESTINATION, FALSE, &pItem))
|
|
|
|
{
|
|
|
|
nBackgroundDestination = ((SfxUInt16Item*)pItem)->GetValue();
|
|
|
|
aUsrPref.SetTblDest((BYTE)nBackgroundDestination);
|
|
|
|
SW_MOD()->ApplyUsrPref(aUsrPref, &rSh.GetView());
|
|
|
|
}
|
|
|
|
FASTBOOL bBorder = ( SFX_ITEM_SET == rSet.GetItemState( RES_BOX ) ||
|
|
|
|
SFX_ITEM_SET == rSet.GetItemState( SID_ATTR_BORDER_INNER ) );
|
|
|
|
pItem = 0;
|
|
|
|
BOOL bBackground = SFX_ITEM_SET == rSet.GetItemState( RES_BACKGROUND, FALSE, &pItem );
|
|
|
|
const SfxPoolItem* pRowItem = 0, *pTableItem = 0;
|
|
|
|
bBackground |= SFX_ITEM_SET == rSet.GetItemState( SID_ATTR_BRUSH_ROW, FALSE, &pRowItem );
|
|
|
|
bBackground |= SFX_ITEM_SET == rSet.GetItemState( SID_ATTR_BRUSH_TABLE, FALSE, &pTableItem );
|
2004-01-13 10:27:07 +00:00
|
|
|
const SfxPoolItem* pSplit = 0;
|
|
|
|
BOOL bRowSplit = SFX_ITEM_SET == rSet.GetItemState( RES_ROW_SPLIT, FALSE, &pSplit );
|
2004-04-21 09:00:22 +00:00
|
|
|
const SfxPoolItem* pBoxDirection = 0;
|
|
|
|
BOOL bBoxDirection = SFX_ITEM_SET == rSet.GetItemState( FN_TABLE_BOX_TEXTDIRECTION, FALSE, &pBoxDirection );
|
|
|
|
if( bBackground || bBorder || bRowSplit || bBoxDirection)
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
|
|
|
/*
|
|
|
|
Die Umrandung wird auf die vorliegende Selektion angewendet
|
|
|
|
Liegt keine Selektion vor, wird die Tabelle vollstaendig selektiert.
|
|
|
|
Der Hintergrund wird immer auf den aktuellen Zustand angewendet.
|
|
|
|
*/
|
|
|
|
|
|
|
|
FASTBOOL bTableSel = rSh.IsTableMode();
|
|
|
|
rSh.StartAllAction();
|
|
|
|
|
|
|
|
if(bBackground)
|
|
|
|
{
|
|
|
|
if(pItem)
|
|
|
|
rSh.SetBoxBackground( *(const SvxBrushItem*)pItem );
|
|
|
|
if(pRowItem)
|
|
|
|
{
|
|
|
|
SvxBrushItem aBrush(*(const SvxBrushItem*)pRowItem);
|
|
|
|
aBrush.SetWhich(RES_BACKGROUND);
|
|
|
|
rSh.SetRowBackground(aBrush);
|
|
|
|
}
|
|
|
|
if(pTableItem)
|
|
|
|
{
|
|
|
|
SvxBrushItem aBrush(*(const SvxBrushItem*)pTableItem);
|
|
|
|
aBrush.SetWhich(RES_BACKGROUND);
|
|
|
|
rSh.SetTabBackground( aBrush );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-04-21 09:00:22 +00:00
|
|
|
if(bBoxDirection)
|
|
|
|
{
|
|
|
|
SvxFrameDirectionItem aDirection;
|
|
|
|
aDirection.SetValue(static_cast< const SvxFrameDirectionItem* >(pBoxDirection)->GetValue());
|
|
|
|
rSh.SetBoxDirection(aDirection);
|
|
|
|
}
|
|
|
|
|
2004-01-13 10:27:07 +00:00
|
|
|
if(bBorder || bRowSplit)
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
|
|
|
rSh.Push();
|
|
|
|
if(!bTableSel)
|
|
|
|
{
|
|
|
|
rSh.GetView().GetViewFrame()->GetDispatcher()->Execute( FN_TABLE_SELECT_ALL );
|
|
|
|
}
|
2004-01-13 10:27:07 +00:00
|
|
|
if(bBorder)
|
|
|
|
rSh.SetTabBorders( rSet );
|
|
|
|
|
|
|
|
if(bRowSplit)
|
|
|
|
{
|
|
|
|
rSh.SetRowSplit(*static_cast<const SwFmtRowSplit*>(pSplit));
|
|
|
|
}
|
2000-09-18 16:15:01 +00:00
|
|
|
|
|
|
|
if(!bTableSel)
|
|
|
|
{
|
|
|
|
rSh.ClearMark();
|
|
|
|
}
|
|
|
|
rSh.Pop(FALSE);
|
|
|
|
}
|
2004-01-13 10:27:07 +00:00
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
rSh.EndAllAction();
|
|
|
|
}
|
|
|
|
|
|
|
|
SwTabCols aTabCols;
|
|
|
|
BOOL bTabCols = FALSE;
|
|
|
|
BOOL bSingleLine = FALSE;
|
|
|
|
SwTableRep* pRep = 0;
|
|
|
|
SwFrmFmt *pFmt = rSh.GetTableFmt();
|
|
|
|
SfxItemSet aSet( rSh.GetAttrPool(), RES_FRMATR_BEGIN, RES_FRMATR_END-1 );
|
|
|
|
if(SFX_ITEM_SET == rSet.GetItemState( FN_TABLE_REP, FALSE, &pItem ))
|
|
|
|
{
|
|
|
|
pRep = (SwTableRep*)((const SwPtrItem*)pItem)->GetValue();
|
|
|
|
|
|
|
|
const SwTwips nWidth = pRep->GetWidth();
|
|
|
|
if ( HORI_FULL == (SwHoriOrient)pRep->GetAlign() )
|
|
|
|
{
|
|
|
|
SwFmtHoriOrient aAttr( pFmt->GetHoriOrient() );
|
|
|
|
aAttr.SetHoriOrient( HORI_FULL );
|
|
|
|
aSet.Put( aAttr );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
SwFmtFrmSize aSz( ATT_VAR_SIZE, nWidth );
|
|
|
|
if(pRep->GetWidthPercent())
|
|
|
|
{
|
|
|
|
aSz.SetWidthPercent( (BYTE)pRep->GetWidthPercent() );
|
|
|
|
}
|
|
|
|
aSet.Put(aSz);
|
|
|
|
}
|
|
|
|
|
|
|
|
SvxLRSpaceItem aLRSpace( RES_LR_SPACE );
|
|
|
|
aLRSpace.SetLeft(pRep->GetLeftSpace());
|
|
|
|
aLRSpace.SetRight(pRep->GetRightSpace());
|
|
|
|
aSet.Put( aLRSpace );
|
|
|
|
|
|
|
|
SwHoriOrient eOrient = (SwHoriOrient)pRep->GetAlign();
|
|
|
|
SwFmtHoriOrient aAttr( 0, eOrient );
|
|
|
|
aSet.Put( aAttr );
|
|
|
|
// Damit beim recording die Ausrichtung nicht durch die Abstaende ueberschrieben
|
|
|
|
// wird, darf das Item nur bei manueller Ausrichtung aufgez. werden
|
|
|
|
if(eOrient != HORI_NONE)
|
|
|
|
((SfxItemSet&)rSet).ClearItem( SID_ATTR_LRSPACE );
|
|
|
|
|
|
|
|
|
|
|
|
if(pRep->HasColsChanged())
|
|
|
|
{
|
|
|
|
bTabCols = TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if( SFX_ITEM_SET == rSet.GetItemState( FN_PARAM_TABLE_HEADLINE, FALSE, &pItem))
|
2004-05-03 12:54:38 +00:00
|
|
|
rSh.SetRowsToRepeat( ((SfxUInt16Item*)pItem)->GetValue() );
|
2000-09-18 16:15:01 +00:00
|
|
|
|
|
|
|
if( SFX_ITEM_SET == rSet.GetItemState( FN_TABLE_SET_VERT_ALIGN, FALSE, &pItem))
|
|
|
|
rSh.SetBoxAlign(((SfxUInt16Item*)(pItem))->GetValue());
|
|
|
|
|
|
|
|
if( SFX_ITEM_SET == rSet.GetItemState( FN_PARAM_TABLE_NAME, FALSE, &pItem ))
|
|
|
|
rSh.SetTableName( *pFmt, ((const SfxStringItem*)pItem)->GetValue() );
|
|
|
|
|
|
|
|
// kopiere die ausgesuchten Attribute in den ItemSet
|
|
|
|
static USHORT __READONLY_DATA aIds[] =
|
|
|
|
{
|
2002-06-17 10:11:16 +00:00
|
|
|
RES_PAGEDESC,
|
|
|
|
RES_BREAK,
|
|
|
|
RES_KEEP,
|
|
|
|
RES_LAYOUT_SPLIT,
|
|
|
|
RES_UL_SPACE,
|
|
|
|
RES_SHADOW,
|
|
|
|
RES_FRAMEDIR,
|
2004-07-12 12:37:44 +00:00
|
|
|
// --> collapsing borders FME 2005-05-27 #i29550#
|
|
|
|
RES_COLLAPSING_BORDERS,
|
|
|
|
// <-- collapsing borders
|
2000-09-18 16:15:01 +00:00
|
|
|
0
|
|
|
|
};
|
|
|
|
for( const USHORT* pIds = aIds; *pIds; ++pIds )
|
|
|
|
if( SFX_ITEM_SET == rSet.GetItemState( *pIds, FALSE, &pItem))
|
|
|
|
aSet.Put( *pItem );
|
|
|
|
|
|
|
|
if( aSet.Count() )
|
|
|
|
rSh.SetTblAttr( aSet );
|
|
|
|
|
|
|
|
if(bTabCols)
|
|
|
|
{
|
|
|
|
rSh.GetTabCols( aTabCols );
|
|
|
|
bSingleLine = pRep->FillTabCols( aTabCols );
|
|
|
|
rSh.SetTabCols( aTabCols, bSingleLine );
|
|
|
|
}
|
|
|
|
|
|
|
|
rSh.EndUndo( UNDO_TABLE_ATTR );
|
|
|
|
rSh.EndAllAction();
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************/
|
|
|
|
|
|
|
|
|
2004-08-23 08:08:29 +00:00
|
|
|
static void lcl_TabGetMaxLineWidth(const SvxBorderLine* pBorderLine, SvxBorderLine& rBorderLine)
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
|
|
|
if(pBorderLine->GetInWidth() > rBorderLine.GetInWidth())
|
|
|
|
rBorderLine.SetInWidth(pBorderLine->GetInWidth());
|
|
|
|
|
|
|
|
if(pBorderLine->GetOutWidth() > rBorderLine.GetOutWidth())
|
|
|
|
rBorderLine.SetOutWidth(pBorderLine->GetOutWidth());
|
|
|
|
|
|
|
|
if(pBorderLine->GetDistance() > rBorderLine.GetDistance())
|
|
|
|
rBorderLine.SetDistance(pBorderLine->GetDistance());
|
|
|
|
|
|
|
|
rBorderLine.SetColor(pBorderLine->GetColor());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SwTableShell::Execute(SfxRequest &rReq)
|
|
|
|
{
|
2002-07-19 10:16:36 +00:00
|
|
|
BOOL bUseDialog = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
const SfxItemSet* pArgs = rReq.GetArgs();
|
|
|
|
SwWrtShell &rSh = GetShell();
|
|
|
|
|
|
|
|
//Erstmal die Slots, die keinen FrmMgr benoetigen.
|
|
|
|
BOOL bMore = FALSE;
|
|
|
|
const SfxPoolItem* pItem = 0;
|
|
|
|
USHORT nSlot = rReq.GetSlot();
|
|
|
|
if(pArgs)
|
|
|
|
pArgs->GetItemState(GetPool().GetWhich(nSlot), FALSE, &pItem);
|
2003-08-19 11:00:16 +00:00
|
|
|
BOOL bCallDone = FALSE;
|
2000-09-18 16:15:01 +00:00
|
|
|
switch ( nSlot )
|
|
|
|
{
|
|
|
|
case SID_ATTR_BORDER:
|
|
|
|
{
|
|
|
|
/* BOOL bPopCrsr = FALSE;
|
|
|
|
if ( !rReq.IsAPI() )
|
|
|
|
{
|
|
|
|
//Keine Tabellenselektion -> Aenderung wird auf die gesamte
|
|
|
|
//Tabelle.
|
|
|
|
if ( !rSh.IsTableMode() )
|
|
|
|
{
|
|
|
|
rSh.StartAction();
|
|
|
|
bPopCrsr = TRUE;
|
|
|
|
rSh.Push();
|
|
|
|
rSh.EnterStdMode();
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableStart );
|
|
|
|
rSh.SttSelect();
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableEnd );
|
|
|
|
rSh.EndSelect();
|
|
|
|
}
|
|
|
|
}*/
|
|
|
|
if(!pArgs)
|
|
|
|
break;
|
|
|
|
//Items erzeugen, weil wir sowieso nacharbeiten muessen
|
|
|
|
SvxBoxItem aBox;
|
|
|
|
SfxItemSet aCoreSet( GetPool(),
|
|
|
|
RES_BOX, RES_BOX,
|
2004-04-21 09:00:22 +00:00
|
|
|
SID_ATTR_BORDER_INNER, SID_ATTR_BORDER_INNER,
|
|
|
|
0);
|
2000-09-18 16:15:01 +00:00
|
|
|
SvxBoxInfoItem aCoreInfo;
|
|
|
|
aCoreSet.Put(aCoreInfo);
|
|
|
|
rSh.GetTabBorders( aCoreSet );
|
|
|
|
const SvxBoxItem& rCoreBox = (const SvxBoxItem&)
|
|
|
|
aCoreSet.Get(RES_BOX);
|
|
|
|
const SfxPoolItem *pItem = 0;
|
|
|
|
if ( pArgs->GetItemState(RES_BOX, TRUE, &pItem) == SFX_ITEM_SET )
|
|
|
|
{
|
|
|
|
aBox = *(SvxBoxItem*)pItem;
|
|
|
|
if ( !rReq.IsAPI() )
|
|
|
|
aBox.SetDistance( Max(rCoreBox.GetDistance(),USHORT(55)) );
|
|
|
|
else if ( aBox.GetDistance() < MIN_BORDER_DIST )
|
|
|
|
aBox.SetDistance( Max(rCoreBox.GetDistance(),(USHORT)MIN_BORDER_DIST) );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{ASSERT( !this, "Wo ist das Box-Item?" )}
|
|
|
|
|
|
|
|
SvxBoxInfoItem aInfo;
|
|
|
|
if (pArgs->GetItemState(SID_ATTR_BORDER_INNER, TRUE, &pItem) == SFX_ITEM_SET)
|
|
|
|
aInfo = *(SvxBoxInfoItem*)pItem;
|
|
|
|
aInfo.SetTable( TRUE );
|
|
|
|
aInfo.SetValid( VALID_DISABLE, FALSE );
|
|
|
|
|
|
|
|
|
|
|
|
// Die Attribute aller Linien werden gelesen und das staerkste gewinnt
|
|
|
|
const SvxBorderLine* pBorderLine;
|
|
|
|
SvxBorderLine aBorderLine;
|
|
|
|
if ((pBorderLine = rCoreBox.GetTop()) != NULL)
|
|
|
|
lcl_TabGetMaxLineWidth(pBorderLine, aBorderLine);
|
|
|
|
if ((pBorderLine = rCoreBox.GetBottom()) != NULL)
|
|
|
|
lcl_TabGetMaxLineWidth(pBorderLine, aBorderLine);
|
|
|
|
if ((pBorderLine = rCoreBox.GetLeft()) != NULL)
|
|
|
|
lcl_TabGetMaxLineWidth(pBorderLine, aBorderLine);
|
|
|
|
if ((pBorderLine = rCoreBox.GetRight()) != NULL)
|
|
|
|
lcl_TabGetMaxLineWidth(pBorderLine, aBorderLine);
|
|
|
|
if ((pBorderLine = aCoreInfo.GetHori()) != NULL)
|
|
|
|
lcl_TabGetMaxLineWidth(pBorderLine, aBorderLine);
|
|
|
|
if ((pBorderLine = aCoreInfo.GetVert()) != NULL)
|
|
|
|
lcl_TabGetMaxLineWidth(pBorderLine, aBorderLine);
|
|
|
|
|
|
|
|
if(aBorderLine.GetOutWidth() == 0)
|
|
|
|
{
|
|
|
|
aBorderLine.SetInWidth(0);
|
|
|
|
aBorderLine.SetOutWidth(DEF_LINE_WIDTH_0);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL bLine = FALSE;
|
|
|
|
if ( (pBorderLine = aBox.GetTop()) != NULL)
|
|
|
|
aBox.SetLine(&aBorderLine, BOX_LINE_TOP), bLine |= TRUE;
|
|
|
|
if ((pBorderLine = aBox.GetBottom()) != NULL)
|
|
|
|
aBox.SetLine(&aBorderLine, BOX_LINE_BOTTOM), bLine |= TRUE;
|
|
|
|
if ((pBorderLine = aBox.GetLeft()) != NULL)
|
|
|
|
aBox.SetLine(&aBorderLine, BOX_LINE_LEFT), bLine |= TRUE;
|
|
|
|
if ((pBorderLine = aBox.GetRight()) != NULL)
|
|
|
|
aBox.SetLine(&aBorderLine, BOX_LINE_RIGHT), bLine |= TRUE;
|
|
|
|
if ((pBorderLine = aInfo.GetHori()) != NULL)
|
|
|
|
aInfo.SetLine(&aBorderLine, BOXINFO_LINE_HORI), bLine |= TRUE;
|
|
|
|
if ((pBorderLine = aInfo.GetVert()) != NULL)
|
|
|
|
aInfo.SetLine(&aBorderLine, BOXINFO_LINE_VERT), bLine |= TRUE;
|
|
|
|
|
|
|
|
// if ( bPopCrsr && !bLine )
|
|
|
|
// aBox.SetDistance( 0 );
|
|
|
|
|
|
|
|
aCoreSet.Put( aBox );
|
|
|
|
aCoreSet.Put( aInfo );
|
|
|
|
rSh.SetTabBorders( aCoreSet );
|
|
|
|
|
2002-07-19 10:16:36 +00:00
|
|
|
// we must record the "real" values because otherwise the lines can't be reconstructed on playtime
|
|
|
|
// the coding style of the controller (setting lines with width 0) is not transportable via Query/PutValue in
|
|
|
|
// the SvxBoxItem
|
|
|
|
rReq.AppendItem( aBox );
|
|
|
|
rReq.AppendItem( aInfo );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2002-07-19 10:16:36 +00:00
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
/* if ( bPopCrsr )
|
|
|
|
{
|
|
|
|
rSh.KillPams();
|
|
|
|
rSh.Pop(FALSE);
|
|
|
|
rSh.EndAction();
|
|
|
|
}*/
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_INSERT_TABLE:
|
2004-06-01 06:46:15 +00:00
|
|
|
InsertTable( rReq );
|
|
|
|
break;
|
2000-09-18 16:15:01 +00:00
|
|
|
case FN_FORMAT_TABLE_DLG:
|
|
|
|
{
|
|
|
|
SfxItemSet aCoreSet( GetPool(), aUITableAttrRange);
|
|
|
|
|
2001-06-19 09:53:51 +00:00
|
|
|
FieldUnit eMetric = ::GetDfltMetric(0 != PTR_CAST(SwWebView, &rSh.GetView()));
|
|
|
|
SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, eMetric));
|
2000-09-18 16:15:01 +00:00
|
|
|
SwTableRep* pTblRep = ::lcl_TableParamToItemSet( aCoreSet, rSh );
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwTableTabDlg* pDlg = NULL;
|
|
|
|
SfxAbstractTabDialog * pDlg = NULL;
|
2002-07-19 10:16:36 +00:00
|
|
|
if ( bUseDialog )
|
2004-05-10 15:35:51 +00:00
|
|
|
{
|
|
|
|
//CHINA001 pDlg = new SwTableTabDlg( GetView().GetWindow(), GetPool(), &aCoreSet, &rSh);
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
|
|
|
|
pDlg = pFact->CreateSwTableTabDlg( GetView().GetWindow(), GetPool(), &aCoreSet, &rSh,ResId( DLG_FORMAT_TABLE ));
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
|
|
|
}
|
2000-09-18 16:15:01 +00:00
|
|
|
aCoreSet.Put(SfxUInt16Item(SID_HTML_MODE, ::GetHtmlMode(GetView().GetDocShell())));
|
|
|
|
rSh.GetTblAttr(aCoreSet);
|
|
|
|
// GetTblAttr buegelt den Background ueber!
|
|
|
|
SvxBrushItem aBrush( RES_BACKGROUND );
|
2001-10-26 13:17:20 +00:00
|
|
|
if(rSh.GetBoxBackground(aBrush))
|
|
|
|
aCoreSet.Put( aBrush );
|
|
|
|
else
|
|
|
|
aCoreSet.InvalidateItem( RES_BACKGROUND );
|
2000-09-18 16:15:01 +00:00
|
|
|
|
2002-07-19 10:16:36 +00:00
|
|
|
if ( !pDlg && rReq.GetArgs() || pDlg->Execute() == RET_OK )
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
2002-07-19 10:16:36 +00:00
|
|
|
const SfxItemSet* pOutSet = pDlg ? pDlg->GetOutputItemSet() : rReq.GetArgs();
|
|
|
|
if ( pDlg )
|
2003-08-19 11:38:23 +00:00
|
|
|
{
|
|
|
|
//to record FN_INSERT_TABLE correctly
|
|
|
|
rReq.SetSlot(FN_FORMAT_TABLE_DLG);
|
2002-07-19 10:16:36 +00:00
|
|
|
rReq.Done( *pOutSet );
|
2003-08-19 11:38:23 +00:00
|
|
|
}
|
2004-08-23 08:08:29 +00:00
|
|
|
ItemSetToTableParam( *pOutSet, rSh );
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
2002-07-19 10:16:36 +00:00
|
|
|
|
2000-09-18 16:15:01 +00:00
|
|
|
delete pDlg;
|
|
|
|
delete pTblRep;
|
|
|
|
SfxBindings& rBindings = GetView().GetViewFrame()->GetBindings();
|
|
|
|
rBindings.Update(SID_RULER_BORDERS);
|
|
|
|
rBindings.Update(SID_ATTR_TABSTOP);
|
2002-03-07 09:23:27 +00:00
|
|
|
rBindings.Update(SID_RULER_BORDERS_VERTICAL);
|
|
|
|
rBindings.Update(SID_ATTR_TABSTOP_VERTICAL);
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
break;
|
2003-08-19 11:38:23 +00:00
|
|
|
case SID_ATTR_BRUSH:
|
|
|
|
case SID_ATTR_BRUSH_ROW :
|
|
|
|
case SID_ATTR_BRUSH_TABLE :
|
|
|
|
if(rReq.GetArgs())
|
2004-08-23 08:08:29 +00:00
|
|
|
ItemSetToTableParam(*rReq.GetArgs(), rSh);
|
2003-08-19 11:38:23 +00:00
|
|
|
break;
|
2000-09-18 16:15:01 +00:00
|
|
|
case FN_NUM_FORMAT_TABLE_DLG:
|
|
|
|
{
|
|
|
|
SwView* pView = GetActiveView();
|
|
|
|
if(pView)
|
|
|
|
{
|
|
|
|
FieldUnit eMetric = ::GetDfltMetric(0 != PTR_CAST(SwWebView, pView));
|
|
|
|
SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, eMetric));
|
|
|
|
SvNumberFormatter* pFormatter = rSh.GetNumberFormatter();
|
|
|
|
SfxItemSet aCoreSet( GetPool(),
|
|
|
|
SID_ATTR_NUMBERFORMAT_VALUE, SID_ATTR_NUMBERFORMAT_VALUE,
|
|
|
|
SID_ATTR_NUMBERFORMAT_INFO, SID_ATTR_NUMBERFORMAT_INFO,
|
|
|
|
0 );
|
|
|
|
|
|
|
|
SfxItemSet aBoxSet( *aCoreSet.GetPool(),
|
|
|
|
RES_BOXATR_FORMAT, RES_BOXATR_FORMAT,
|
|
|
|
RES_BOXATR_VALUE, RES_BOXATR_VALUE,
|
|
|
|
0 );
|
|
|
|
rSh.GetTblBoxFormulaAttrs( aBoxSet );
|
|
|
|
|
|
|
|
SfxItemState eState = aBoxSet.GetItemState(RES_BOXATR_FORMAT);
|
|
|
|
if(eState == SFX_ITEM_DEFAULT)
|
|
|
|
{
|
|
|
|
aCoreSet.Put( SfxUInt32Item( SID_ATTR_NUMBERFORMAT_VALUE,
|
|
|
|
pFormatter->GetFormatIndex(NF_TEXT, LANGUAGE_SYSTEM)));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
aCoreSet.Put( SfxUInt32Item( SID_ATTR_NUMBERFORMAT_VALUE,
|
|
|
|
((SwTblBoxNumFormat&)aBoxSet.Get(
|
|
|
|
RES_BOXATR_FORMAT )).GetValue() ));
|
|
|
|
|
2001-03-12 17:47:57 +00:00
|
|
|
String sCurText( rSh.GetTableBoxText() );
|
2000-09-18 16:15:01 +00:00
|
|
|
aCoreSet.Put( SvxNumberInfoItem( pFormatter,
|
|
|
|
((SwTblBoxValue&)aBoxSet.Get(
|
|
|
|
RES_BOXATR_VALUE)).GetValue(),
|
2001-03-12 17:47:57 +00:00
|
|
|
sCurText, SID_ATTR_NUMBERFORMAT_INFO ));
|
2000-09-18 16:15:01 +00:00
|
|
|
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwNumFmtDlg* pDlg = new SwNumFmtDlg( GetView().GetWindow(),
|
|
|
|
//CHINA001 aCoreSet );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
|
|
|
|
AbstractSfxSingleTabDialog* pDlg = pFact->CreateSfxSingleTabDialog( GetView().GetWindow(),aCoreSet,ResId( RC_DLG_SWNUMFMTDLG ));
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
|
|
|
|
if (RET_OK == pDlg->Execute())
|
|
|
|
{
|
|
|
|
const SfxPoolItem* pItem = GetView().GetDocShell()->
|
|
|
|
GetItem( SID_ATTR_NUMBERFORMAT_INFO );
|
|
|
|
|
|
|
|
if( pItem && 0 != ((SvxNumberInfoItem*)pItem)->GetDelCount() )
|
|
|
|
{
|
|
|
|
const ULONG* pDelArr = ((SvxNumberInfoItem*)
|
|
|
|
pItem)->GetDelArray();
|
|
|
|
|
|
|
|
for ( USHORT i = 0; i < ((SvxNumberInfoItem*)pItem)->GetDelCount(); i++ )
|
|
|
|
((SvxNumberInfoItem*)pItem)->
|
|
|
|
GetNumberFormatter()->DeleteEntry( pDelArr[i] );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( SFX_ITEM_SET == pDlg->GetOutputItemSet()->GetItemState(
|
|
|
|
SID_ATTR_NUMBERFORMAT_VALUE, FALSE, &pItem ))
|
|
|
|
{
|
|
|
|
SfxItemSet aBoxSet( *aCoreSet.GetPool(),
|
|
|
|
RES_BOXATR_FORMAT, RES_BOXATR_FORMAT );
|
|
|
|
aBoxSet.Put( SwTblBoxNumFormat(
|
|
|
|
((SfxUInt32Item*)pItem)->GetValue() ));
|
|
|
|
rSh.SetTblBoxFormulaAttrs( aBoxSet );
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_CALC_TABLE:
|
|
|
|
rSh.UpdateTable();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_OPTIMAL_HEIGHT:
|
|
|
|
{
|
|
|
|
const SwFmtFrmSize aSz;
|
|
|
|
rSh.SetRowHeight( aSz );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_DELETE_COL:
|
|
|
|
if ( rSh.DeleteCol() && rSh.HasSelection() )
|
|
|
|
rSh.EnterStdMode();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_END_TABLE:
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableEnd );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_START_TABLE:
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableStart );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
2002-10-18 08:30:14 +00:00
|
|
|
case FN_GOTO_NEXT_CELL:
|
|
|
|
{
|
|
|
|
BOOL bAppendLine = TRUE;
|
|
|
|
if( pItem )
|
|
|
|
bAppendLine = ((SfxBoolItem*)pItem)->GetValue();
|
|
|
|
rReq.SetReturnValue( SfxBoolItem( nSlot,
|
|
|
|
rSh.GoNextCell( bAppendLine ) ) );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2002-10-18 08:30:14 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_GOTO_PREV_CELL:
|
|
|
|
rReq.SetReturnValue( SfxBoolItem( nSlot, rSh.GoPrevCell() ) );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2002-10-18 08:30:14 +00:00
|
|
|
break;
|
2000-09-18 16:15:01 +00:00
|
|
|
case FN_TABLE_DELETE_ROW:
|
|
|
|
if ( rSh.DeleteRow() && rSh.HasSelection() )
|
|
|
|
rSh.EnterStdMode();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_MERGE_CELLS:
|
|
|
|
if ( rSh.IsTableMode() )
|
|
|
|
switch ( rSh.MergeTab() )
|
|
|
|
{
|
|
|
|
case TBLMERGE_OK:
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
|
|
|
//no break;
|
2000-09-18 16:15:01 +00:00
|
|
|
case TBLMERGE_NOSELECTION: break;
|
|
|
|
case TBLMERGE_TOOCOMPLEX:
|
|
|
|
{
|
|
|
|
InfoBox aInfoBox( GetView().GetWindow(),
|
|
|
|
SW_RES( MSG_ERR_TABLE_MERGE ) );
|
|
|
|
aInfoBox.Execute();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default: ASSERT( !this, "unbekannter Returnwert MergeTab.");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_ADJUST_CELLS:
|
|
|
|
case FN_TABLE_BALANCE_CELLS:
|
2003-04-17 09:16:29 +00:00
|
|
|
{
|
|
|
|
BOOL bBalance = (FN_TABLE_BALANCE_CELLS == nSlot);
|
|
|
|
if ( rSh.IsAdjustCellWidthAllowed(bBalance) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// remove actions to make a valid table selection
|
|
|
|
UnoActionRemoveContext aRemoveContext(rSh.GetDoc());
|
|
|
|
}
|
|
|
|
rSh.AdjustCellWidth(bBalance);
|
|
|
|
}
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2003-04-17 09:16:29 +00:00
|
|
|
}
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_BALANCE_ROWS:
|
|
|
|
if ( rSh.BalanceRowHeight(TRUE) )
|
|
|
|
rSh.BalanceRowHeight(FALSE);
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_SELECT_ALL:
|
|
|
|
rSh.EnterStdMode();
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableStart );
|
|
|
|
rSh.SttSelect();
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableEnd );
|
|
|
|
rSh.EndSelect();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_SELECT_COL:
|
|
|
|
rSh.EnterStdMode();
|
|
|
|
rSh.SelectTableCol();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_SELECT_ROW:
|
|
|
|
rSh.EnterStdMode();
|
|
|
|
rSh.SelectTableRow();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_SET_READ_ONLY_CELLS:
|
|
|
|
rSh.ProtectCells();
|
|
|
|
rSh.ResetSelect( 0, FALSE );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case FN_TABLE_UNSET_READ_ONLY_CELLS:
|
|
|
|
rSh.UnProtectCells();
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
case SID_AUTOFORMAT:
|
|
|
|
{
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwAutoFormatDlg* pDlg = new SwAutoFormatDlg(
|
|
|
|
//CHINA001 &GetView().GetViewFrame()->GetWindow(), &rSh );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
|
|
|
|
AbstractSwAutoFormatDlg* pDlg = pFact->CreateSwAutoFormatDlg(&GetView().GetViewFrame()->GetWindow(), &rSh ,ResId( DLG_AUTOFMT_TABLE ) );
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
pDlg->Execute();
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_SET_ROW_HEIGHT:
|
|
|
|
{
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwTableHeightDlg *pDlg = new SwTableHeightDlg(
|
|
|
|
//CHINA001 GetView().GetWindow(), rSh );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
|
|
|
|
VclAbstractDialog* pDlg = pFact->CreateVclAbstractDialog( GetView().GetWindow(), rSh,ResId( DLG_ROW_HEIGHT ));
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
pDlg->Execute();
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_NUMBER_BULLETS:
|
|
|
|
case FN_NUM_BULLET_ON:
|
|
|
|
ASSERT( !this, "Funktion darf zur Zeit nicht gerufen werden." );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_INSERT_COL:
|
|
|
|
case FN_TABLE_INSERT_ROW:
|
|
|
|
{
|
|
|
|
BOOL bColumn = rReq.GetSlot() == FN_TABLE_INSERT_COL;
|
|
|
|
USHORT nCount = 0;
|
|
|
|
BOOL bAfter = TRUE;
|
|
|
|
if (pItem)
|
|
|
|
{
|
|
|
|
nCount = ((const SfxInt16Item* )pItem)->GetValue();
|
|
|
|
if(SFX_ITEM_SET == pArgs->GetItemState(FN_PARAM_INSERT_AFTER, TRUE, &pItem))
|
|
|
|
bAfter = ((const SfxBoolItem* )pItem)->GetValue();
|
|
|
|
}
|
|
|
|
else if( !rReq.IsAPI() )
|
|
|
|
++nCount;
|
|
|
|
|
|
|
|
if( nCount )
|
|
|
|
{
|
|
|
|
if( bColumn )
|
|
|
|
rSh.InsertCol( nCount, bAfter );
|
|
|
|
else if ( !rSh.IsInRepeatedHeadline() )
|
|
|
|
rSh.InsertRow( nCount, bAfter );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
nSlot = bColumn ? FN_TABLE_INSERT_COL_DLG : FN_TABLE_INSERT_ROW_DLG;
|
|
|
|
}
|
|
|
|
// kein break; bei Count = 0 kommt der Dialog
|
|
|
|
case FN_TABLE_INSERT_COL_DLG:
|
|
|
|
case FN_TABLE_INSERT_ROW_DLG:
|
|
|
|
{
|
|
|
|
if ( FN_TABLE_INSERT_ROW_DLG != nSlot || !rSh.IsInRepeatedHeadline())
|
|
|
|
{
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwInsRowColDlg *pDlg = new SwInsRowColDlg( GetView(),
|
|
|
|
//CHINA001 FN_TABLE_INSERT_COL_DLG == nSlot );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
|
|
|
|
DBG_ASSERT(pFact, "Dialogdiet fail!");//CHINA001
|
|
|
|
VclAbstractDialog* pDlg = pFact->CreateVclSwViewDialog( ResId(DLG_INS_ROW_COL),
|
|
|
|
GetView(), FN_TABLE_INSERT_COL_DLG == nSlot );
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
pDlg->Execute();
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_SPLIT_CELLS:
|
|
|
|
{
|
2002-07-19 10:16:36 +00:00
|
|
|
long nCount=0;
|
|
|
|
BOOL bHorizontal=TRUE;
|
2002-11-22 06:32:08 +00:00
|
|
|
BOOL bProportional = FALSE;
|
2002-07-19 10:16:36 +00:00
|
|
|
SFX_REQUEST_ARG( rReq, pSplit, SfxInt32Item, FN_TABLE_SPLIT_CELLS, sal_False );
|
|
|
|
SFX_REQUEST_ARG( rReq, pHor, SfxBoolItem, FN_PARAM_1, sal_False );
|
2002-11-22 06:32:08 +00:00
|
|
|
SFX_REQUEST_ARG( rReq, pProp, SfxBoolItem, FN_PARAM_2, sal_False );
|
2002-07-19 10:16:36 +00:00
|
|
|
if ( pSplit )
|
|
|
|
{
|
|
|
|
nCount = pSplit->GetValue();
|
|
|
|
if ( pHor )
|
|
|
|
bHorizontal = pHor->GetValue();
|
2002-11-22 06:32:08 +00:00
|
|
|
if ( pProp )
|
|
|
|
bProportional = pProp->GetValue();
|
2002-07-19 10:16:36 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwSplitTableDlg *pDlg = new SwSplitTableDlg( GetView().GetWindow(), rSh );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
|
|
|
|
AbstractSwSplitTableDlg* pDlg = pFact->CreateSwSplitTableDlg( GetView().GetWindow(), rSh,ResId( DLG_SPLIT ));
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
2002-07-19 10:16:36 +00:00
|
|
|
if ( pDlg->Execute() == RET_OK )
|
|
|
|
{
|
|
|
|
nCount = pDlg->GetCount();
|
|
|
|
bHorizontal = pDlg->IsHorizontal();
|
2002-11-22 06:32:08 +00:00
|
|
|
bProportional = pDlg->IsProportional();
|
2002-07-19 10:16:36 +00:00
|
|
|
rReq.AppendItem( SfxInt32Item( FN_TABLE_SPLIT_CELLS, nCount ) );
|
|
|
|
rReq.AppendItem( SfxBoolItem( FN_PARAM_1, bHorizontal ) );
|
2002-11-22 06:32:08 +00:00
|
|
|
rReq.AppendItem( SfxBoolItem( FN_PARAM_2, bProportional ) );
|
2002-07-19 10:16:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( nCount>1 )
|
|
|
|
{
|
2004-06-01 06:46:15 +00:00
|
|
|
rSh.SplitTab(!bHorizontal, static_cast< USHORT >( nCount-1 ), bProportional );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2002-07-19 10:16:36 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
rReq.Ignore();
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_SPLIT_TABLE:
|
|
|
|
{
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwSplitTblDlg *pDlg = new SwSplitTblDlg( GetView().GetWindow(), rSh );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
|
|
|
|
VclAbstractDialog* pDlg = pFact->CreateVclAbstractDialog( GetView().GetWindow(), rSh ,ResId( DLG_SPLIT_TABLE ));
|
|
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");//CHINA001
|
2000-09-18 16:15:01 +00:00
|
|
|
pDlg->Execute();
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_MERGE_TABLE:
|
|
|
|
{
|
|
|
|
BOOL bPrev = rSh.CanMergeTable( TRUE );
|
|
|
|
BOOL bNext = rSh.CanMergeTable( FALSE );
|
|
|
|
|
|
|
|
if( bPrev && bNext )
|
|
|
|
{
|
|
|
|
// Dialog: welche denn?
|
2004-05-10 15:35:51 +00:00
|
|
|
//CHINA001 SwMergeTblDlg* pDlg = new SwMergeTblDlg(
|
|
|
|
//CHINA001 GetView().GetWindow(), bPrev );
|
|
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();//CHINA001
|
|
|
|
DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");//CHINA001
|
|
|
|
VclAbstractDialog* pDlg = pFact->CreateSwVclDialog( ResId( DLG_MERGE_TABLE ), GetView().GetWindow(), bPrev );
|
|
|
|
DBG_ASSERT(pDlg, "dialogdiet pDlg fail!");//CHINA001
|
|
|
|
if( RET_OK != pDlg->Execute())
|
2000-09-18 16:15:01 +00:00
|
|
|
bPrev = bNext = FALSE;
|
|
|
|
delete pDlg;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( bPrev || bNext )
|
|
|
|
rSh.MergeTable( bPrev );
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_MODE_FIX :
|
|
|
|
case FN_TABLE_MODE_FIX_PROP :
|
|
|
|
case FN_TABLE_MODE_VARIABLE :
|
|
|
|
{
|
|
|
|
rSh.SetTblChgMode( ( FN_TABLE_MODE_FIX == nSlot ? TBLFIX_CHGABS
|
|
|
|
: FN_TABLE_MODE_FIX_PROP == nSlot
|
|
|
|
? TBLFIX_CHGPROP
|
|
|
|
: TBLVAR_CHGABS ) );
|
|
|
|
|
|
|
|
SfxBindings& rBind = GetView().GetViewFrame()->GetBindings();
|
|
|
|
static USHORT __READONLY_DATA aInva[] =
|
|
|
|
{ FN_TABLE_MODE_FIX,
|
|
|
|
FN_TABLE_MODE_FIX_PROP,
|
|
|
|
FN_TABLE_MODE_VARIABLE,
|
|
|
|
0
|
|
|
|
};
|
|
|
|
rBind.Invalidate( aInva );
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_AUTOSUM:
|
|
|
|
{
|
|
|
|
SfxViewFrame* pVFrame = GetView().GetViewFrame();
|
|
|
|
pVFrame->GetDispatcher()->Execute(FN_EDIT_FORMULA, SFX_CALLMODE_SYNCHRON);
|
|
|
|
const USHORT nId = SwInputChild::GetChildWindowId();
|
|
|
|
SwInputChild* pChildWin = (SwInputChild*)pVFrame->
|
|
|
|
GetChildWindow( nId );
|
|
|
|
String sSum;
|
|
|
|
GetShell().GetAutoSum(sSum);
|
|
|
|
if( pChildWin )
|
|
|
|
pChildWin->SetFormula( sSum );
|
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
2004-08-02 12:09:46 +00:00
|
|
|
case FN_TABLE_HEADLINE_REPEAT:
|
|
|
|
if(0 != rSh.GetRowsToRepeat())
|
|
|
|
rSh.SetRowsToRepeat( 0 );
|
|
|
|
else
|
|
|
|
rSh.SetRowsToRepeat(rSh.GetRowSelectionFromTop());
|
|
|
|
break;
|
|
|
|
case FN_TABLE_SELECT_CELL :
|
|
|
|
rSh.SelectTableCell();
|
|
|
|
break;
|
|
|
|
case FN_TABLE_DELETE_TABLE :
|
|
|
|
{
|
|
|
|
rSh.StartAction();
|
|
|
|
rSh.StartUndo();
|
|
|
|
rSh.GetView().GetViewFrame()->GetDispatcher()->Execute(FN_TABLE_SELECT_ALL);
|
|
|
|
rSh.DeleteRow();
|
|
|
|
rSh.EndUndo();
|
|
|
|
rSh.EndAction();
|
|
|
|
}
|
|
|
|
//'this' is already destroyed
|
|
|
|
return;
|
|
|
|
//break;
|
2000-09-18 16:15:01 +00:00
|
|
|
default:
|
|
|
|
bMore = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( !bMore )
|
|
|
|
{
|
2003-08-19 11:00:16 +00:00
|
|
|
if(bCallDone)
|
|
|
|
rReq.Done();
|
2000-09-18 16:15:01 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
bMore = FALSE;
|
|
|
|
//Jetzt die Slots, die direkt auf dem TableFmt arbeiten.
|
|
|
|
SwFrmFmt *pFmt = rSh.GetTableFmt();
|
|
|
|
switch ( nSlot )
|
|
|
|
{
|
|
|
|
case SID_ATTR_ULSPACE:
|
|
|
|
{
|
|
|
|
if(pItem)
|
|
|
|
{
|
|
|
|
SvxULSpaceItem aULSpace( *(const SvxULSpaceItem*)pItem );
|
|
|
|
aULSpace.SetWhich( RES_UL_SPACE );
|
|
|
|
::lcl_SetAttr( rSh, aULSpace );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SID_ATTR_LRSPACE:
|
|
|
|
{
|
|
|
|
if(pItem)
|
|
|
|
{
|
|
|
|
SfxItemSet aSet( GetPool(), RES_LR_SPACE, RES_LR_SPACE,
|
|
|
|
RES_HORI_ORIENT, RES_HORI_ORIENT, 0 );
|
|
|
|
SvxLRSpaceItem aLRSpace( *(const SvxLRSpaceItem*)pItem );
|
|
|
|
aLRSpace.SetWhich( RES_LR_SPACE );
|
|
|
|
aSet.Put( aLRSpace );
|
|
|
|
SwFmtHoriOrient aHori( pFmt->GetHoriOrient() );
|
|
|
|
aHori.SetHoriOrient( HORI_NONE );
|
|
|
|
aSet.Put( aLRSpace );
|
|
|
|
rSh.SetTblAttr( aSet );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
// der letzte case-Zweig der noch einen TabellenManager braucht!!
|
|
|
|
case FN_TABLE_SET_COL_WIDTH:
|
|
|
|
{
|
|
|
|
SwTableFUNC aMgr( &rSh, FALSE);
|
|
|
|
aMgr.ColWidthDlg(GetView().GetWindow());
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_VERT_NONE:
|
|
|
|
case FN_TABLE_VERT_CENTER:
|
|
|
|
case FN_TABLE_VERT_BOTTOM:
|
|
|
|
{
|
|
|
|
USHORT nAlign = nSlot == FN_TABLE_VERT_NONE ?
|
|
|
|
VERT_NONE :
|
|
|
|
nSlot == FN_TABLE_VERT_CENTER ?
|
|
|
|
VERT_CENTER : VERT_BOTTOM;
|
|
|
|
rSh.SetBoxAlign(nAlign);
|
2003-08-19 11:00:16 +00:00
|
|
|
bCallDone = TRUE;
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SID_ATTR_PARA_SPLIT:
|
|
|
|
if ( pItem )
|
|
|
|
{
|
|
|
|
SwFmtLayoutSplit aSplit( ((const SvxFmtSplitItem*)pItem)->GetValue());
|
|
|
|
SfxItemSet aSet(GetPool(), RES_LAYOUT_SPLIT, RES_LAYOUT_SPLIT, 0 );
|
|
|
|
aSet.Put(aSplit);
|
|
|
|
rSh.SetTblAttr(aSet);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SID_ATTR_PARA_KEEP:
|
|
|
|
if ( pItem )
|
|
|
|
{
|
|
|
|
SvxFmtKeepItem aKeep( *(const SvxFmtKeepItem*)pItem );
|
|
|
|
aKeep.SetWhich( RES_KEEP );
|
|
|
|
SfxItemSet aSet(GetPool(), RES_KEEP, RES_KEEP, 0 );
|
|
|
|
aSet.Put(aKeep);
|
|
|
|
rSh.SetTblAttr(aSet);
|
|
|
|
}
|
|
|
|
break;
|
2004-01-13 10:27:07 +00:00
|
|
|
case FN_TABLE_ROW_SPLIT :
|
|
|
|
{
|
|
|
|
const SfxBoolItem* pBool = static_cast<const SfxBoolItem*>(pItem);
|
|
|
|
SwFmtRowSplit* pSplit = 0;
|
|
|
|
if(!pBool)
|
|
|
|
{
|
|
|
|
rSh.GetRowSplit(pSplit);
|
|
|
|
if(pSplit)
|
|
|
|
pSplit->SetValue(!pSplit->GetValue());
|
|
|
|
else
|
|
|
|
pSplit = new SwFmtRowSplit(TRUE);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
pSplit = new SwFmtRowSplit(pBool->GetValue());
|
|
|
|
}
|
|
|
|
rSh.SetRowSplit( *pSplit );
|
|
|
|
delete pSplit;
|
|
|
|
}
|
|
|
|
break;
|
2000-09-18 16:15:01 +00:00
|
|
|
|
|
|
|
default:
|
|
|
|
ASSERT( !this, "falscher Dispatcher" );
|
|
|
|
return;
|
|
|
|
}
|
2003-08-19 11:00:16 +00:00
|
|
|
if(bCallDone)
|
|
|
|
rReq.Done();
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
|
|
Beschreibung:
|
|
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
void SwTableShell::GetState(SfxItemSet &rSet)
|
|
|
|
{
|
|
|
|
SfxWhichIter aIter( rSet );
|
|
|
|
SwWrtShell &rSh = GetShell();
|
|
|
|
SwFrmFmt *pFmt = rSh.GetTableFmt();
|
2005-11-04 15:02:31 +00:00
|
|
|
// os #124829# crash report: in case of an invalid shell selection return immediately
|
|
|
|
if(!pFmt)
|
|
|
|
return;
|
2000-09-18 16:15:01 +00:00
|
|
|
USHORT nSlot = aIter.FirstWhich();
|
|
|
|
while ( nSlot )
|
|
|
|
{
|
|
|
|
switch ( nSlot )
|
|
|
|
{
|
|
|
|
case FN_TABLE_MERGE_CELLS:
|
|
|
|
if ( !rSh.IsTableMode() )
|
|
|
|
rSet.DisableItem(FN_TABLE_MERGE_CELLS);
|
|
|
|
break;
|
|
|
|
case FN_TABLE_ADJUST_CELLS:
|
|
|
|
if ( !rSh.IsAdjustCellWidthAllowed() )
|
|
|
|
rSet.DisableItem(FN_TABLE_ADJUST_CELLS);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_BALANCE_CELLS:
|
|
|
|
if ( !rSh.IsAdjustCellWidthAllowed(TRUE) )
|
|
|
|
rSet.DisableItem(FN_TABLE_BALANCE_CELLS);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_BALANCE_ROWS:
|
|
|
|
if ( !rSh.BalanceRowHeight(TRUE) )
|
|
|
|
rSet.DisableItem(FN_TABLE_BALANCE_ROWS);
|
|
|
|
break;
|
2001-06-05 06:47:18 +00:00
|
|
|
case FN_OPTIMIZE_TABLE:
|
|
|
|
if ( !rSh.IsTableMode() &&
|
|
|
|
!rSh.IsAdjustCellWidthAllowed() &&
|
|
|
|
!rSh.IsAdjustCellWidthAllowed(TRUE) &&
|
|
|
|
!rSh.BalanceRowHeight(TRUE) )
|
|
|
|
rSet.DisableItem(FN_OPTIMIZE_TABLE);
|
|
|
|
break;
|
2000-09-18 16:15:01 +00:00
|
|
|
case SID_INSERT_DIAGRAM:
|
2000-11-14 17:32:27 +00:00
|
|
|
{
|
|
|
|
SvtModuleOptions aMOpt;
|
|
|
|
if ( !aMOpt.IsMath() || rSh.IsTblComplexForChart() )
|
|
|
|
rSet.DisableItem(nSlot);
|
|
|
|
}
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_INSERT_TABLE:
|
|
|
|
// Irgendeinen Wert "putten", damit Controller enabled bleibt.
|
|
|
|
// Statt "Insert:Table" erscheint dann "Format:Table".
|
2004-06-01 06:46:15 +00:00
|
|
|
// rSet.Put(SfxUInt16Item(nSlot, 1));
|
2000-09-18 16:15:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_OPTIMAL_HEIGHT:
|
|
|
|
{
|
|
|
|
//Disablen wenn bereits auto-Hoehe eingestellt ist.
|
|
|
|
SwFmtFrmSize *pSz;
|
|
|
|
rSh.GetRowHeight( pSz );
|
|
|
|
if ( pSz )
|
|
|
|
{
|
2004-05-18 14:01:26 +00:00
|
|
|
if ( ATT_VAR_SIZE == pSz->GetHeightSizeType() )
|
2000-09-18 16:15:01 +00:00
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
delete pSz;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_INSERT_ROW:
|
|
|
|
case FN_TABLE_INSERT_ROW_DLG:
|
|
|
|
{
|
|
|
|
if ( rSh.IsInRepeatedHeadline() )
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case RES_LR_SPACE:
|
|
|
|
rSet.Put(pFmt->GetLRSpace());
|
|
|
|
break;
|
|
|
|
case RES_UL_SPACE:
|
|
|
|
rSet.Put(pFmt->GetULSpace());
|
|
|
|
break;
|
|
|
|
case FN_TABLE_VERT_NONE:
|
|
|
|
case FN_TABLE_VERT_CENTER:
|
|
|
|
case FN_TABLE_VERT_BOTTOM:
|
|
|
|
{
|
|
|
|
USHORT nAlign = rSh.GetBoxAlign();
|
|
|
|
BOOL bSet = nSlot == FN_TABLE_VERT_NONE && nAlign == VERT_NONE||
|
|
|
|
nSlot == FN_TABLE_VERT_CENTER && nAlign == VERT_CENTER ||
|
|
|
|
nSlot == FN_TABLE_VERT_BOTTOM && nAlign == VERT_BOTTOM;
|
|
|
|
rSet.Put(SfxBoolItem(nSlot, bSet));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_MODE_FIX :
|
|
|
|
case FN_TABLE_MODE_FIX_PROP :
|
|
|
|
case FN_TABLE_MODE_VARIABLE :
|
|
|
|
{
|
|
|
|
USHORT nMode = rSh.GetTblChgMode();
|
|
|
|
BOOL bSet = nSlot == FN_TABLE_MODE_FIX && nMode == TBLFIX_CHGABS ||
|
|
|
|
nSlot == FN_TABLE_MODE_FIX_PROP && nMode == TBLFIX_CHGPROP ||
|
|
|
|
nSlot == FN_TABLE_MODE_VARIABLE && nMode == TBLVAR_CHGABS;
|
|
|
|
rSet.Put(SfxBoolItem(nSlot, bSet));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SID_ATTR_PARA_SPLIT:
|
|
|
|
rSet.Put( pFmt->GetKeep() );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SID_ATTR_PARA_KEEP:
|
|
|
|
rSet.Put( pFmt->GetLayoutSplit() );
|
|
|
|
break;
|
|
|
|
case FN_TABLE_SPLIT_TABLE:
|
|
|
|
{
|
|
|
|
if ( rSh.IsInHeadline() )
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_MERGE_TABLE:
|
|
|
|
{
|
|
|
|
BOOL bAsk;
|
|
|
|
if( !rSh.CanMergeTable( TRUE, &bAsk ))
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2004-01-13 10:27:07 +00:00
|
|
|
case FN_TABLE_DELETE_ROW:
|
|
|
|
{
|
|
|
|
SwSelBoxes aBoxes;
|
|
|
|
::GetTblSel( rSh, aBoxes, TBLSEARCH_ROW );
|
|
|
|
if( ::HasProtectedCells( aBoxes ))
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_TABLE_DELETE_COL:
|
|
|
|
{
|
|
|
|
SwSelBoxes aBoxes;
|
|
|
|
::GetTblSel( rSh, aBoxes, TBLSEARCH_COL );
|
|
|
|
if( ::HasProtectedCells( aBoxes ))
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case FN_TABLE_UNSET_READ_ONLY_CELLS:
|
|
|
|
// disable in readonly sections, but enable in protected cells
|
|
|
|
if( !rSh.CanUnProtectCells() )
|
2000-09-18 16:15:01 +00:00
|
|
|
rSet.DisableItem( nSlot );
|
2004-01-13 10:27:07 +00:00
|
|
|
break;
|
|
|
|
case RES_ROW_SPLIT:
|
2000-09-18 16:15:01 +00:00
|
|
|
{
|
2004-01-13 10:27:07 +00:00
|
|
|
const SwFmtLayoutSplit& rTabSplit = pFmt->GetLayoutSplit();
|
|
|
|
if ( 0 == rTabSplit.GetValue() )
|
|
|
|
{
|
2000-09-18 16:15:01 +00:00
|
|
|
rSet.DisableItem( nSlot );
|
2004-01-13 10:27:07 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
SwFmtRowSplit* pSplit = 0;
|
|
|
|
rSh.GetRowSplit(pSplit);
|
|
|
|
if(pSplit)
|
|
|
|
rSet.Put(*pSplit);
|
|
|
|
else
|
|
|
|
rSet.InvalidateItem( nSlot );
|
|
|
|
delete pSplit;
|
|
|
|
}
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
break;
|
2004-08-02 12:09:46 +00:00
|
|
|
case FN_TABLE_HEADLINE_REPEAT:
|
|
|
|
if(0 != rSh.GetRowsToRepeat())
|
|
|
|
rSet.Put(SfxBoolItem(nSlot, sal_True));
|
|
|
|
else if(!rSh.GetRowSelectionFromTop())
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
else
|
|
|
|
rSet.Put(SfxBoolItem(nSlot, sal_False));
|
|
|
|
break;
|
|
|
|
case FN_TABLE_SELECT_CELL :
|
|
|
|
if(rSh.HasBoxSelection())
|
|
|
|
rSet.DisableItem( nSlot );
|
|
|
|
break;
|
2000-09-18 16:15:01 +00:00
|
|
|
}
|
|
|
|
nSlot = aIter.NextWhich();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*--------------------------------------------------------------------
|
|
|
|
Beschreibung:
|
|
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
SwTableShell::SwTableShell(SwView &rView) :
|
|
|
|
SwBaseShell(rView)
|
|
|
|
{
|
|
|
|
SetName(String::CreateFromAscii("Table"));
|
|
|
|
SetHelpId(SW_TABSHELL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*--------------------------------------------------------------------
|
|
|
|
Beschreibung:
|
|
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
void SwTableShell::GetFrmBorderState(SfxItemSet &rSet)
|
|
|
|
{
|
|
|
|
SfxItemSet aCoreSet( GetPool(),
|
|
|
|
RES_BOX, RES_BOX,
|
|
|
|
SID_ATTR_BORDER_INNER, SID_ATTR_BORDER_INNER, 0 );
|
|
|
|
SvxBoxInfoItem aBoxInfo;
|
|
|
|
aCoreSet.Put( aBoxInfo );
|
|
|
|
GetShell().GetTabBorders( aCoreSet );
|
|
|
|
rSet.Put( aCoreSet );
|
|
|
|
}
|
|
|
|
|
|
|
|
/*--------------------------------------------------------------------
|
|
|
|
Beschreibung:
|
|
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
void SwTableShell::ExecTableStyle(SfxRequest& rReq)
|
|
|
|
{
|
|
|
|
SwWrtShell &rSh = GetShell();
|
|
|
|
const SfxItemSet *pArgs = rReq.GetArgs();
|
|
|
|
if(pArgs)
|
|
|
|
switch ( rReq.GetSlot() )
|
|
|
|
{
|
|
|
|
case SID_FRAME_LINESTYLE:
|
|
|
|
case SID_FRAME_LINECOLOR:
|
|
|
|
{
|
|
|
|
/* Tabellenselektion ist abgeschafft
|
|
|
|
BOOL bPopCrsr = FALSE;
|
|
|
|
if ( !rReq.IsAPI() )
|
|
|
|
{
|
|
|
|
//Keine Tabellenselektion -> Aenderung wird auf die gesamte
|
|
|
|
//Tabelle.
|
|
|
|
if ( !rSh.IsTableMode() )
|
|
|
|
{
|
|
|
|
bPopCrsr = TRUE;
|
|
|
|
rSh.Push();
|
|
|
|
rSh.StartAction();
|
|
|
|
rSh.EnterStdMode();
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableStart );
|
|
|
|
rSh.SttSelect();
|
|
|
|
rSh.MoveTable( fnTableCurr, fnTableEnd );
|
|
|
|
rSh.EndSelect();
|
|
|
|
}
|
|
|
|
}*/
|
|
|
|
if ( rReq.GetSlot() == SID_FRAME_LINESTYLE )
|
|
|
|
{
|
|
|
|
const SvxLineItem &rLineItem = (const SvxLineItem&)pArgs->
|
|
|
|
Get( SID_FRAME_LINESTYLE );
|
|
|
|
const SvxBorderLine* pBorderLine = rLineItem.GetLine();
|
|
|
|
rSh.SetTabLineStyle( 0, TRUE, pBorderLine);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
const SvxColorItem &rNewColorItem = (const SvxColorItem&)pArgs->
|
|
|
|
Get( SID_FRAME_LINECOLOR );
|
|
|
|
rSh.SetTabLineStyle( &rNewColorItem.GetValue() );
|
|
|
|
}
|
2002-07-19 10:16:36 +00:00
|
|
|
|
|
|
|
rReq.Done();
|
2000-09-18 16:15:01 +00:00
|
|
|
/* if ( bPopCrsr )
|
|
|
|
{
|
|
|
|
rSh.KillPams();
|
|
|
|
rSh.Pop(FALSE);
|
|
|
|
rSh.EndAction();
|
|
|
|
}*/
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SwTableShell::GetLineStyleState(SfxItemSet &rSet)
|
|
|
|
{
|
|
|
|
SfxItemSet aCoreSet( GetPool(),
|
|
|
|
RES_BOX, RES_BOX,
|
|
|
|
SID_ATTR_BORDER_INNER, SID_ATTR_BORDER_INNER, 0);
|
|
|
|
SvxBoxInfoItem aCoreInfo;
|
|
|
|
aCoreSet.Put(aCoreInfo);
|
|
|
|
GetShell().GetTabBorders( aCoreSet );
|
|
|
|
|
|
|
|
const SvxBoxItem& rBoxItem = (const SvxBoxItem&)aCoreSet.Get( RES_BOX );
|
|
|
|
const SvxBorderLine* pLine = rBoxItem.GetTop();
|
|
|
|
|
|
|
|
rSet.Put( SvxColorItem( pLine ? pLine->GetColor() : Color(), SID_FRAME_LINECOLOR ) );
|
|
|
|
SvxLineItem aLine( SID_FRAME_LINESTYLE );
|
|
|
|
aLine.SetLine(pLine);
|
|
|
|
rSet.Put( aLine );
|
|
|
|
}
|
|
|
|
|
|
|
|
void SwTableShell::ExecNumberFormat(SfxRequest& rReq)
|
|
|
|
{
|
|
|
|
const SfxItemSet* pArgs = rReq.GetArgs();
|
|
|
|
SwWrtShell &rSh = GetShell();
|
|
|
|
|
|
|
|
//Erstmal die Slots, die keinen FrmMgr benoetigen.
|
|
|
|
const SfxPoolItem* pItem = 0;
|
|
|
|
USHORT nSlot = rReq.GetSlot();
|
|
|
|
if(pArgs)
|
|
|
|
pArgs->GetItemState(GetPool().GetWhich(nSlot), FALSE, &pItem);
|
|
|
|
|
|
|
|
// Sprache immer von Cursorposition besorgen
|
2001-02-21 16:38:36 +00:00
|
|
|
LanguageType eLang = rSh.GetCurLang();
|
2000-09-18 16:15:01 +00:00
|
|
|
SvNumberFormatter* pFormatter = rSh.GetNumberFormatter();
|
|
|
|
ULONG nNumberFormat = NUMBERFORMAT_ENTRY_NOT_FOUND;
|
|
|
|
USHORT nFmtType = 0, nOffset = 0;
|
|
|
|
|
|
|
|
switch ( nSlot )
|
|
|
|
{
|
|
|
|
case FN_NUMBER_FORMAT:
|
|
|
|
if( pItem )
|
|
|
|
{
|
|
|
|
// Index fuer String bestimmen
|
|
|
|
String aCode( ((const SfxStringItem*)pItem)->GetValue() );
|
|
|
|
nNumberFormat = pFormatter->GetEntryKey( aCode, eLang );
|
|
|
|
if( NUMBERFORMAT_ENTRY_NOT_FOUND == nNumberFormat )
|
|
|
|
{
|
|
|
|
// neu eintragen
|
|
|
|
xub_StrLen nErrPos;
|
|
|
|
short nType;
|
|
|
|
if( !pFormatter->PutEntry( aCode, nErrPos, nType,
|
|
|
|
nNumberFormat, eLang ))
|
|
|
|
nNumberFormat = NUMBERFORMAT_ENTRY_NOT_FOUND;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case FN_NUMBER_STANDARD: nFmtType = NUMBERFORMAT_NUMBER; break;
|
|
|
|
case FN_NUMBER_SCIENTIFIC: nFmtType = NUMBERFORMAT_SCIENTIFIC; break;
|
|
|
|
case FN_NUMBER_DATE: nFmtType = NUMBERFORMAT_DATE; break;
|
|
|
|
case FN_NUMBER_TIME: nFmtType = NUMBERFORMAT_TIME; break;
|
|
|
|
case FN_NUMBER_CURRENCY: nFmtType = NUMBERFORMAT_CURRENCY; break;
|
|
|
|
case FN_NUMBER_PERCENT: nFmtType = NUMBERFORMAT_PERCENT; break;
|
|
|
|
|
|
|
|
case FN_NUMBER_TWODEC: // #.##0,00
|
|
|
|
nFmtType = NUMBERFORMAT_NUMBER;
|
|
|
|
nOffset = NF_NUMBER_1000DEC2;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
ASSERT(FALSE, falscher Dispatcher);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( nFmtType )
|
|
|
|
nNumberFormat = pFormatter->GetStandardFormat( nFmtType, eLang ) + nOffset;
|
|
|
|
|
|
|
|
if( NUMBERFORMAT_ENTRY_NOT_FOUND != nNumberFormat )
|
|
|
|
{
|
2001-02-21 16:38:36 +00:00
|
|
|
SfxItemSet aBoxSet( GetPool(), RES_BOXATR_FORMAT, RES_BOXATR_FORMAT );
|
2000-09-18 16:15:01 +00:00
|
|
|
aBoxSet.Put( SwTblBoxNumFormat( nNumberFormat ));
|
|
|
|
rSh.SetTblBoxFormulaAttrs( aBoxSet );
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|