Change-Id: I345a2802b4428c607297cbe6972c5b7aebc5de0b Reviewed-on: https://gerrit.libreoffice.org/5439 Reviewed-by: Petr Mladek <pmladek@suse.cz> Tested-by: Petr Mladek <pmladek@suse.cz>
2474 lines
94 KiB
C++
2474 lines
94 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* 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 .
|
|
*/
|
|
|
|
#include <com/sun/star/util/SearchOptions.hpp>
|
|
#include <com/sun/star/util/SearchFlags.hpp>
|
|
#include <com/sun/star/i18n/TransliterationModules.hpp>
|
|
#include <vcl/graphicfilter.hxx>
|
|
#include <com/sun/star/sdb/DatabaseContext.hpp>
|
|
#include <com/sun/star/ui/dialogs/XFilePickerControlAccess.hpp>
|
|
#include <com/sun/star/ui/dialogs/ExtendedFilePickerElementIds.hpp>
|
|
#include <com/sun/star/ui/dialogs/ListboxControlActions.hpp>
|
|
#include <com/sun/star/ui/dialogs/TemplateDescription.hpp>
|
|
#include <svl/aeitem.hxx>
|
|
#include <SwStyleNameMapper.hxx>
|
|
#include <docary.hxx>
|
|
#include <hintids.hxx>
|
|
#include <SwRewriter.hxx>
|
|
#include <numrule.hxx>
|
|
#include <swundo.hxx>
|
|
#include <caption.hxx>
|
|
#include <svl/PasswordHelper.hxx>
|
|
#include <svl/urihelper.hxx>
|
|
#include <svtools/miscopt.hxx>
|
|
#include <sfx2/passwd.hxx>
|
|
#include <sfx2/sfxdlg.hxx>
|
|
#include <sfx2/filedlghelper.hxx>
|
|
#include <sfx2/sfxhelp.hxx>
|
|
#include <editeng/langitem.hxx>
|
|
#include <svx/viewlayoutitem.hxx>
|
|
#include <svx/zoomslideritem.hxx>
|
|
#include <svtools/xwindowitem.hxx>
|
|
#include <svx/linkwarn.hxx>
|
|
#include <sfx2/htmlmode.hxx>
|
|
#include <vcl/svapp.hxx>
|
|
#include <vcl/wrkwin.hxx>
|
|
#include <sfx2/app.hxx>
|
|
#include <sfx2/request.hxx>
|
|
#include <sfx2/bindings.hxx>
|
|
#include <editeng/lrspitem.hxx>
|
|
#include <unotools/textsearch.hxx>
|
|
#include "editeng/unolingu.hxx"
|
|
#include <vcl/msgbox.hxx>
|
|
#include <editeng/tstpitem.hxx>
|
|
#include <sfx2/event.hxx>
|
|
#include <sfx2/docfile.hxx>
|
|
#include <sfx2/docfilt.hxx>
|
|
#include <sfx2/fcontnr.hxx>
|
|
#include <editeng/sizeitem.hxx>
|
|
#include <sfx2/dispatch.hxx>
|
|
#include <svl/whiter.hxx>
|
|
#include <svl/ptitem.hxx>
|
|
#include <sfx2/linkmgr.hxx>
|
|
#include <tools/errinf.hxx>
|
|
#include <tools/urlobj.hxx>
|
|
#include <svx/svdview.hxx>
|
|
#include <swtypes.hxx>
|
|
#include <swwait.hxx>
|
|
#include <redlndlg.hxx>
|
|
#include <view.hxx>
|
|
#include <uivwimp.hxx>
|
|
#include <docsh.hxx>
|
|
#include <doc.hxx>
|
|
#include <IDocumentUndoRedo.hxx>
|
|
#include <wrtsh.hxx>
|
|
#include <viewopt.hxx>
|
|
#include <basesh.hxx>
|
|
#include <swmodule.hxx>
|
|
#include <uitool.hxx>
|
|
#include <shellio.hxx>
|
|
#include <fmtinfmt.hxx>
|
|
#include <mdiexp.hxx>
|
|
#include <drawbase.hxx>
|
|
#include <frmmgr.hxx>
|
|
#include <pagedesc.hxx>
|
|
#include <section.hxx>
|
|
#include <usrpref.hxx>
|
|
#include <IMark.hxx>
|
|
#include <navipi.hxx>
|
|
#include <tox.hxx>
|
|
#include <workctrl.hxx>
|
|
#include <scroll.hxx>
|
|
#include <edtwin.hxx>
|
|
#include <wview.hxx>
|
|
#include <textsh.hxx>
|
|
#include <tabsh.hxx>
|
|
#include <listsh.hxx>
|
|
#include <cmdid.h>
|
|
#include <comcore.hrc>
|
|
#include <poolfmt.hrc>
|
|
#include <statstr.hrc>
|
|
#include <swerror.h>
|
|
#include <globals.hrc>
|
|
#include <shells.hrc>
|
|
#include <web.hrc>
|
|
#include <view.hrc>
|
|
#include <app.hrc>
|
|
#include <fmtclds.hxx>
|
|
#include <helpid.h>
|
|
#include <svtools/templdlg.hxx>
|
|
#include <dbconfig.hxx>
|
|
#include <dbmgr.hxx>
|
|
#include <reffld.hxx>
|
|
|
|
#include <PostItMgr.hxx>
|
|
|
|
#include <ndtxt.hxx>
|
|
|
|
#include <comphelper/processfactory.hxx>
|
|
#include <comphelper/string.hxx>
|
|
|
|
#include <svx/svxdlg.hxx>
|
|
#include <svx/dialogs.hrc>
|
|
#include "swabstdlg.hxx"
|
|
#include "globals.hrc"
|
|
#include <envelp.hrc>
|
|
#include <fmthdft.hxx>
|
|
#include <svx/ofaitem.hxx>
|
|
#include <unomid.h>
|
|
#include <docstat.hxx>
|
|
#include <wordcountdialog.hxx>
|
|
|
|
#include <vcl/GraphicNativeTransform.hxx>
|
|
#include <vcl/GraphicNativeMetadata.hxx>
|
|
|
|
const char sStatusDelim[] = " : ";
|
|
const char sStatusComma[] = " , ";//#outlinelevel, define a Variable for "," add by zhaojianwei
|
|
|
|
using namespace sfx2;
|
|
using namespace ::com::sun::star;
|
|
using namespace ::com::sun::star::i18n;
|
|
using namespace ::com::sun::star::util;
|
|
using namespace ::com::sun::star::uno;
|
|
using namespace ::com::sun::star::lang;
|
|
using namespace ::com::sun::star::scanner;
|
|
using namespace ::com::sun::star::beans;
|
|
using namespace ::com::sun::star::container;
|
|
using namespace ::com::sun::star::sdb;
|
|
using namespace ::com::sun::star::ui::dialogs;
|
|
|
|
static void lcl_SetAllTextToDefaultLanguage( SwWrtShell &rWrtSh, sal_uInt16 nWhichId )
|
|
{
|
|
if (nWhichId == RES_CHRATR_LANGUAGE ||
|
|
nWhichId == RES_CHRATR_CJK_LANGUAGE ||
|
|
nWhichId == RES_CHRATR_CTL_LANGUAGE)
|
|
{
|
|
rWrtSh.StartAction();
|
|
rWrtSh.LockView( sal_True );
|
|
rWrtSh.Push();
|
|
|
|
// prepare to apply new language to all text in document
|
|
rWrtSh.SelAll();
|
|
rWrtSh.ExtendedSelectAll();
|
|
|
|
// set language attribute to default for all text
|
|
std::set<sal_uInt16> aAttribs;
|
|
aAttribs.insert( nWhichId );
|
|
rWrtSh.ResetAttr( aAttribs );
|
|
|
|
rWrtSh.Pop( sal_False );
|
|
rWrtSh.LockView( sal_False );
|
|
rWrtSh.EndAction();
|
|
}
|
|
}
|
|
|
|
/* Create string for showing of page in statusbar */
|
|
String SwView::GetPageStr( sal_uInt16 nPg, sal_uInt16 nLogPg,
|
|
const String& rDisplay )
|
|
{
|
|
String aStr( m_aPageStr );
|
|
if( rDisplay.Len() )
|
|
aStr += rDisplay;
|
|
else
|
|
aStr += OUString::number(nLogPg);
|
|
|
|
if( nLogPg && nLogPg != nPg )
|
|
{
|
|
aStr.AppendAscii( RTL_CONSTASCII_STRINGPARAM(" "));
|
|
aStr += OUString::number(nPg);
|
|
}
|
|
aStr.AppendAscii( RTL_CONSTASCII_STRINGPARAM(" / "));
|
|
aStr += OUString::number( GetWrtShell().GetPageCnt() );
|
|
|
|
return aStr;
|
|
}
|
|
|
|
int SwView::InsertGraphic( const String &rPath, const String &rFilter,
|
|
sal_Bool bLink, GraphicFilter *pFilter,
|
|
Graphic* pPreviewGrf, sal_Bool bRule )
|
|
{
|
|
SwWait aWait( *GetDocShell(), true );
|
|
|
|
Graphic aGraphic;
|
|
int aResult = GRFILTER_OK;
|
|
if ( pPreviewGrf )
|
|
aGraphic = *pPreviewGrf;
|
|
else
|
|
{
|
|
if( !pFilter )
|
|
{
|
|
pFilter = &GraphicFilter::GetGraphicFilter();
|
|
}
|
|
aResult = GraphicFilter::LoadGraphic( rPath, rFilter, aGraphic, pFilter );
|
|
}
|
|
|
|
if( GRFILTER_OK == aResult )
|
|
{
|
|
GraphicNativeMetadata aMetadata;
|
|
if ( aMetadata.read(aGraphic) )
|
|
{
|
|
sal_uInt16 aRotation = aMetadata.getRotation();
|
|
if (aRotation != 0)
|
|
{
|
|
QueryBox aQueryBox(GetWindow(), WB_YES_NO | WB_DEF_YES, SW_RES(STR_ROTATE_TO_STANDARD_ORIENTATION) );
|
|
if (aQueryBox.Execute() == RET_YES)
|
|
{
|
|
GraphicNativeTransform aTransform( aGraphic );
|
|
aTransform.rotate( aRotation );
|
|
}
|
|
}
|
|
}
|
|
|
|
SwFlyFrmAttrMgr aFrameManager( sal_True, GetWrtShellPtr(), FRMMGR_TYPE_GRF );
|
|
|
|
SwWrtShell& rShell = GetWrtShell();
|
|
rShell.StartAction();
|
|
if( bLink )
|
|
{
|
|
SwDocShell* pDocSh = GetDocShell();
|
|
INetURLObject aTemp(
|
|
pDocSh->HasName() ?
|
|
pDocSh->GetMedium()->GetURLObject().GetMainURL( INetURLObject::NO_DECODE ) :
|
|
OUString());
|
|
|
|
String sURL = URIHelper::SmartRel2Abs( aTemp, rPath, URIHelper::GetMaybeFileHdl() );
|
|
|
|
rShell.Insert( sURL, rFilter, aGraphic, &aFrameManager, bRule );
|
|
}
|
|
else
|
|
{
|
|
rShell.Insert( aEmptyStr, aEmptyStr, aGraphic, &aFrameManager );
|
|
}
|
|
|
|
// it is too late after "EndAction" because the Shell can already be destroyed.
|
|
rShell.EndAction();
|
|
}
|
|
return aResult;
|
|
}
|
|
|
|
sal_Bool SwView::InsertGraphicDlg( SfxRequest& rReq )
|
|
{
|
|
sal_Bool bReturn = sal_False;
|
|
SwDocShell* pDocShell = GetDocShell();
|
|
sal_uInt16 nHtmlMode = ::GetHtmlMode(pDocShell);
|
|
// im HTML-Mode nur verknuepft einfuegen
|
|
FileDialogHelper* pFileDlg = new FileDialogHelper(
|
|
ui::dialogs::TemplateDescription::FILEOPEN_LINK_PREVIEW_IMAGE_TEMPLATE,
|
|
SFXWB_GRAPHIC );
|
|
pFileDlg->SetTitle(SW_RESSTR(STR_INSERT_GRAPHIC ));
|
|
pFileDlg->SetContext( FileDialogHelper::SW_INSERT_GRAPHIC );
|
|
uno::Reference < XFilePicker > xFP = pFileDlg->GetFilePicker();
|
|
uno::Reference < XFilePickerControlAccess > xCtrlAcc(xFP, UNO_QUERY);
|
|
if(nHtmlMode & HTMLMODE_ON)
|
|
{
|
|
sal_Bool bTrue = sal_True;
|
|
Any aVal(&bTrue, ::getBooleanCppuType());
|
|
xCtrlAcc->setValue( ExtendedFilePickerElementIds::CHECKBOX_LINK, 0, aVal);
|
|
xCtrlAcc->enableControl( ExtendedFilePickerElementIds::CHECKBOX_LINK, sal_False);
|
|
}
|
|
|
|
std::vector<String> aFormats;
|
|
SwDoc* pDoc = pDocShell->GetDoc();
|
|
const sal_uInt16 nArrLen = pDoc->GetFrmFmts()->size();
|
|
sal_uInt16 i;
|
|
for( i = 0; i < nArrLen; i++ )
|
|
{
|
|
SwFrmFmt* pFmt = (*pDoc->GetFrmFmts())[ i ];
|
|
if(pFmt->IsDefault() || pFmt->IsAuto())
|
|
continue;
|
|
aFormats.push_back(pFmt->GetName());
|
|
}
|
|
|
|
// pool formats
|
|
//
|
|
const ::std::vector<OUString>& rFrmPoolArr(
|
|
SwStyleNameMapper::GetFrmFmtUINameArray());
|
|
for( i = 0; i < rFrmPoolArr.size(); ++i )
|
|
{
|
|
aFormats.push_back(rFrmPoolArr[i]);
|
|
}
|
|
|
|
std::sort(aFormats.begin(), aFormats.end());
|
|
aFormats.erase(std::unique(aFormats.begin(), aFormats.end()), aFormats.end());
|
|
|
|
Sequence<OUString> aListBoxEntries(aFormats.size());
|
|
OUString* pEntries = aListBoxEntries.getArray();
|
|
sal_Int16 nSelect = 0;
|
|
String sGraphicFormat = SW_RESSTR(STR_POOLFRM_GRAPHIC);
|
|
for( i = 0; i < aFormats.size(); i++ )
|
|
{
|
|
pEntries[i] = aFormats[i];
|
|
if(pEntries[i].equals(sGraphicFormat))
|
|
nSelect = i;
|
|
}
|
|
try
|
|
{
|
|
Any aTemplates(&aListBoxEntries, ::getCppuType(&aListBoxEntries));
|
|
|
|
xCtrlAcc->setValue( ExtendedFilePickerElementIds::LISTBOX_IMAGE_TEMPLATE,
|
|
ListboxControlActions::ADD_ITEMS , aTemplates );
|
|
|
|
Any aSelectPos(&nSelect, ::getCppuType(&nSelect));
|
|
xCtrlAcc->setValue( ExtendedFilePickerElementIds::LISTBOX_IMAGE_TEMPLATE,
|
|
ListboxControlActions::SET_SELECT_ITEM, aSelectPos );
|
|
}
|
|
catch (const Exception&)
|
|
{
|
|
OSL_FAIL("control acces failed");
|
|
}
|
|
|
|
SFX_REQUEST_ARG( rReq, pName, SfxStringItem, SID_INSERT_GRAPHIC , sal_False );
|
|
sal_Bool bShowError = !pName;
|
|
if( pName || ERRCODE_NONE == pFileDlg->Execute() )
|
|
{
|
|
|
|
String aFileName, aFilterName;
|
|
if ( pName )
|
|
{
|
|
aFileName = pName->GetValue();
|
|
SFX_REQUEST_ARG( rReq, pFilter, SfxStringItem, FN_PARAM_FILTER , sal_False );
|
|
if ( pFilter )
|
|
aFilterName = pFilter->GetValue();
|
|
}
|
|
else
|
|
{
|
|
aFileName = pFileDlg->GetPath();
|
|
aFilterName = pFileDlg->GetCurrentFilter();
|
|
rReq.AppendItem( SfxStringItem( SID_INSERT_GRAPHIC, aFileName ) );
|
|
rReq.AppendItem( SfxStringItem( FN_PARAM_FILTER, aFilterName ) );
|
|
|
|
sal_Bool bAsLink = sal_False;
|
|
if(nHtmlMode & HTMLMODE_ON)
|
|
bAsLink = sal_True;
|
|
else
|
|
{
|
|
try
|
|
{
|
|
Any aVal = xCtrlAcc->getValue( ExtendedFilePickerElementIds::CHECKBOX_LINK, 0);
|
|
OSL_ENSURE(aVal.hasValue(), "Value CBX_INSERT_AS_LINK not found");
|
|
bAsLink = aVal.hasValue() ? *(sal_Bool*) aVal.getValue() : sal_True;
|
|
Any aTemplateValue = xCtrlAcc->getValue(
|
|
ExtendedFilePickerElementIds::LISTBOX_IMAGE_TEMPLATE,
|
|
ListboxControlActions::GET_SELECTED_ITEM );
|
|
OUString sTmpl;
|
|
aTemplateValue >>= sTmpl;
|
|
rReq.AppendItem( SfxStringItem( FN_PARAM_2, sTmpl) );
|
|
}
|
|
catch (const Exception&)
|
|
{
|
|
OSL_FAIL("control access failed");
|
|
}
|
|
}
|
|
rReq.AppendItem( SfxBoolItem( FN_PARAM_1, bAsLink ) );
|
|
}
|
|
|
|
SFX_REQUEST_ARG( rReq, pAsLink, SfxBoolItem, FN_PARAM_1 , sal_False );
|
|
SFX_REQUEST_ARG( rReq, pStyle, SfxStringItem, FN_PARAM_2 , sal_False );
|
|
|
|
sal_Bool bAsLink = sal_False;
|
|
if( nHtmlMode & HTMLMODE_ON )
|
|
bAsLink = sal_True;
|
|
else
|
|
{
|
|
if ( rReq.GetArgs() )
|
|
{
|
|
if ( pAsLink )
|
|
bAsLink = pAsLink->GetValue();
|
|
if ( pStyle && !pStyle->GetValue().isEmpty() )
|
|
sGraphicFormat = pStyle->GetValue();
|
|
}
|
|
else
|
|
{
|
|
Any aVal = xCtrlAcc->getValue( ExtendedFilePickerElementIds::CHECKBOX_LINK, 0);
|
|
OSL_ENSURE(aVal.hasValue(), "Value CBX_INSERT_AS_LINK not found");
|
|
bAsLink = aVal.hasValue() ? *(sal_Bool*) aVal.getValue() : sal_True;
|
|
Any aTemplateValue = xCtrlAcc->getValue(
|
|
ExtendedFilePickerElementIds::LISTBOX_IMAGE_TEMPLATE,
|
|
ListboxControlActions::GET_SELECTED_ITEM );
|
|
OUString sTmpl;
|
|
aTemplateValue >>= sTmpl;
|
|
if( !sTmpl.isEmpty() )
|
|
sGraphicFormat = sTmpl;
|
|
rReq.AppendItem( SfxStringItem( FN_PARAM_2, sGraphicFormat ) );
|
|
rReq.AppendItem( SfxBoolItem( FN_PARAM_1, bAsLink ) );
|
|
}
|
|
|
|
// really store as link only?
|
|
if( bAsLink && SvtMiscOptions().ShowLinkWarningDialog() )
|
|
{
|
|
SvxLinkWarningDialog aWarnDlg(GetWindow(),pFileDlg->GetPath());
|
|
if( aWarnDlg.Execute() != RET_OK )
|
|
bAsLink=sal_False; // don't store as link
|
|
}
|
|
}
|
|
|
|
SwWrtShell& rSh = GetWrtShell();
|
|
rSh.LockPaint();
|
|
rSh.StartAction();
|
|
|
|
SwRewriter aRewriter;
|
|
aRewriter.AddRule(UndoArg1, SW_RESSTR(STR_GRAPHIC_DEFNAME));
|
|
|
|
rSh.StartUndo(UNDO_INSERT, &aRewriter);
|
|
|
|
int nError = InsertGraphic( aFileName, aFilterName, bAsLink, &GraphicFilter::GetGraphicFilter() );
|
|
|
|
// Format ist ungleich Current Filter, jetzt mit auto. detection
|
|
if( nError == GRFILTER_FORMATERROR )
|
|
nError = InsertGraphic( aFileName, aEmptyStr, bAsLink, &GraphicFilter::GetGraphicFilter() );
|
|
if ( rSh.IsFrmSelected() )
|
|
{
|
|
SwFrmFmt* pFmt = pDoc->FindFrmFmtByName( sGraphicFormat );
|
|
if(!pFmt)
|
|
pFmt = pDoc->MakeFrmFmt(sGraphicFormat,
|
|
pDocShell->GetDoc()->GetDfltFrmFmt(),
|
|
true, false);
|
|
rSh.SetFrmFmt( pFmt );
|
|
}
|
|
|
|
RESOURCE_TYPE nResId = 0;
|
|
switch( nError )
|
|
{
|
|
case GRFILTER_OPENERROR:
|
|
nResId = STR_GRFILTER_OPENERROR;
|
|
break;
|
|
case GRFILTER_IOERROR:
|
|
nResId = STR_GRFILTER_IOERROR;
|
|
break;
|
|
case GRFILTER_FORMATERROR:
|
|
nResId = STR_GRFILTER_FORMATERROR;
|
|
break;
|
|
case GRFILTER_VERSIONERROR:
|
|
nResId = STR_GRFILTER_VERSIONERROR;
|
|
break;
|
|
case GRFILTER_FILTERERROR:
|
|
nResId = STR_GRFILTER_FILTERERROR;
|
|
break;
|
|
case GRFILTER_TOOBIG:
|
|
nResId = STR_GRFILTER_TOOBIG;
|
|
break;
|
|
}
|
|
|
|
rSh.EndAction();
|
|
rSh.UnlockPaint();
|
|
if( nResId )
|
|
{
|
|
if( bShowError )
|
|
{
|
|
InfoBox aInfoBox( GetWindow(), SW_RESSTR( nResId ));
|
|
aInfoBox.Execute();
|
|
}
|
|
rReq.Ignore();
|
|
}
|
|
else
|
|
{
|
|
// set the specific graphic attrbutes to the graphic
|
|
bReturn = sal_True;
|
|
AutoCaption( GRAPHIC_CAP );
|
|
rReq.Done();
|
|
}
|
|
|
|
rSh.EndUndo(); // due to possible change of Shell
|
|
}
|
|
|
|
delete pFileDlg;
|
|
|
|
return bReturn;
|
|
}
|
|
|
|
void SwView::Execute(SfxRequest &rReq)
|
|
{
|
|
sal_uInt16 nSlot = rReq.GetSlot();
|
|
const SfxItemSet* pArgs = rReq.GetArgs();
|
|
const SfxPoolItem* pItem;
|
|
sal_Bool bIgnore = sal_False;
|
|
switch( nSlot )
|
|
{
|
|
case SID_CREATE_SW_DRAWVIEW:
|
|
m_pWrtShell->getIDocumentDrawModelAccess()->GetOrCreateDrawModel();
|
|
break;
|
|
|
|
case FN_LINE_NUMBERING_DLG:
|
|
{
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
|
|
OSL_ENSURE(pFact, "Dialogdiet fail!");
|
|
VclAbstractDialog* pDlg = pFact->CreateVclSwViewDialog(*this);
|
|
OSL_ENSURE(pDlg, "Dialogdiet fail!");
|
|
pDlg->Execute();
|
|
delete pDlg;
|
|
break;
|
|
}
|
|
case FN_EDIT_LINK_DLG:
|
|
EditLinkDlg();
|
|
break;
|
|
case FN_REFRESH_VIEW:
|
|
GetEditWin().Invalidate();
|
|
break;
|
|
case FN_PAGEUP:
|
|
case FN_PAGEUP_SEL:
|
|
case FN_PAGEDOWN:
|
|
case FN_PAGEDOWN_SEL:
|
|
{
|
|
Rectangle aVis( GetVisArea() );
|
|
SwEditWin& rTmpWin = GetEditWin();
|
|
if ( FN_PAGEUP == nSlot || FN_PAGEUP_SEL == nSlot )
|
|
PageUpCrsr(FN_PAGEUP_SEL == nSlot);
|
|
else
|
|
PageDownCrsr(FN_PAGEDOWN_SEL == nSlot);
|
|
|
|
rReq.SetReturnValue(SfxBoolItem(nSlot,
|
|
aVis != GetVisArea()));
|
|
//#i42732# - notify the edit window that from now on we do not use the input language
|
|
rTmpWin.SetUseInputLanguage( sal_False );
|
|
}
|
|
break;
|
|
case FN_REDLINE_ON:
|
|
{
|
|
if( pArgs &&
|
|
SFX_ITEM_SET == pArgs->GetItemState(nSlot, sal_False, &pItem ))
|
|
{
|
|
IDocumentRedlineAccess* pIDRA = m_pWrtShell->getIDocumentRedlineAccess();
|
|
Sequence <sal_Int8> aPasswd = pIDRA->GetRedlinePassword();
|
|
if( aPasswd.getLength() )
|
|
{
|
|
OSL_ENSURE( !((const SfxBoolItem*)pItem)->GetValue(), "SwView::Execute(): password set an redlining off doesn't match!" );
|
|
// xmlsec05: new password dialog
|
|
Window* pParent;
|
|
const SfxPoolItem* pParentItem;
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_ATTR_XWINDOW, sal_False, &pParentItem ) )
|
|
pParent = ( ( const XWindowItem* ) pParentItem )->GetWindowPtr();
|
|
else
|
|
pParent = &GetViewFrame()->GetWindow();
|
|
SfxPasswordDialog aPasswdDlg( pParent );
|
|
aPasswdDlg.SetMinLen( 1 );
|
|
//#i69751# the result of Execute() can be ignored
|
|
aPasswdDlg.Execute();
|
|
String sNewPasswd( aPasswdDlg.GetPassword() );
|
|
Sequence <sal_Int8> aNewPasswd = pIDRA->GetRedlinePassword();
|
|
SvPasswordHelper::GetHashPassword( aNewPasswd, sNewPasswd );
|
|
if(SvPasswordHelper::CompareHashPassword(aPasswd, sNewPasswd))
|
|
pIDRA->SetRedlinePassword(Sequence <sal_Int8> ());
|
|
else
|
|
{ // xmlsec05: message box for wrong password
|
|
break;
|
|
}
|
|
}
|
|
|
|
sal_uInt16 nOn = ((const SfxBoolItem*)pItem)->GetValue() ? nsRedlineMode_t::REDLINE_ON : 0;
|
|
sal_uInt16 nMode = m_pWrtShell->GetRedlineMode();
|
|
m_pWrtShell->SetRedlineModeAndCheckInsMode( (nMode & ~nsRedlineMode_t::REDLINE_ON) | nOn);
|
|
}
|
|
}
|
|
break;
|
|
case FN_REDLINE_PROTECT :
|
|
{
|
|
IDocumentRedlineAccess* pIDRA = m_pWrtShell->getIDocumentRedlineAccess();
|
|
Sequence <sal_Int8> aPasswd = pIDRA->GetRedlinePassword();
|
|
if( pArgs && SFX_ITEM_SET == pArgs->GetItemState(nSlot, sal_False, &pItem )
|
|
&& ((SfxBoolItem*)pItem)->GetValue() == ( aPasswd.getLength() != 0 ) )
|
|
break;
|
|
|
|
// xmlsec05: new password dialog
|
|
// message box for wrong password
|
|
Window* pParent;
|
|
const SfxPoolItem* pParentItem;
|
|
if( pArgs && SFX_ITEM_SET == pArgs->GetItemState( SID_ATTR_XWINDOW, sal_False, &pParentItem ) )
|
|
pParent = ( ( const XWindowItem* ) pParentItem )->GetWindowPtr();
|
|
else
|
|
pParent = &GetViewFrame()->GetWindow();
|
|
SfxPasswordDialog aPasswdDlg( pParent );
|
|
aPasswdDlg.SetMinLen( 1 );
|
|
if(!aPasswd.getLength())
|
|
aPasswdDlg.ShowExtras(SHOWEXTRAS_CONFIRM);
|
|
if (aPasswdDlg.Execute())
|
|
{
|
|
sal_uInt16 nOn = nsRedlineMode_t::REDLINE_ON;
|
|
String sNewPasswd( aPasswdDlg.GetPassword() );
|
|
Sequence <sal_Int8> aNewPasswd =
|
|
pIDRA->GetRedlinePassword();
|
|
SvPasswordHelper::GetHashPassword( aNewPasswd, sNewPasswd );
|
|
if(!aPasswd.getLength())
|
|
{
|
|
pIDRA->SetRedlinePassword(aNewPasswd);
|
|
}
|
|
else if(SvPasswordHelper::CompareHashPassword(aPasswd, sNewPasswd))
|
|
{
|
|
pIDRA->SetRedlinePassword(Sequence <sal_Int8> ());
|
|
nOn = 0;
|
|
}
|
|
sal_uInt16 nMode = pIDRA->GetRedlineMode();
|
|
m_pWrtShell->SetRedlineModeAndCheckInsMode( (nMode & ~nsRedlineMode_t::REDLINE_ON) | nOn);
|
|
rReq.AppendItem( SfxBoolItem( FN_REDLINE_PROTECT, ((nMode&nsRedlineMode_t::REDLINE_ON)==0) ) );
|
|
}
|
|
else
|
|
bIgnore = sal_True;
|
|
}
|
|
break;
|
|
case FN_REDLINE_SHOW:
|
|
|
|
if( pArgs &&
|
|
SFX_ITEM_SET == pArgs->GetItemState(nSlot, sal_False, &pItem))
|
|
{
|
|
sal_uInt16 nMode = ( ~(nsRedlineMode_t::REDLINE_SHOW_INSERT | nsRedlineMode_t::REDLINE_SHOW_DELETE)
|
|
& m_pWrtShell->GetRedlineMode() ) | nsRedlineMode_t::REDLINE_SHOW_INSERT;
|
|
if( ((const SfxBoolItem*)pItem)->GetValue() )
|
|
nMode |= nsRedlineMode_t::REDLINE_SHOW_DELETE;
|
|
|
|
m_pWrtShell->SetRedlineModeAndCheckInsMode( nMode );
|
|
}
|
|
break;
|
|
case FN_MAILMERGE_SENDMAIL_CHILDWINDOW:
|
|
case FN_REDLINE_ACCEPT:
|
|
GetViewFrame()->ToggleChildWindow(nSlot);
|
|
break;
|
|
case FN_REDLINE_ACCEPT_DIRECT:
|
|
case FN_REDLINE_REJECT_DIRECT:
|
|
{
|
|
// We check for a redline at the start of the selection/cursor, not the point.
|
|
// This ensures we work properly with FN_REDLINE_NEXT_CHANGE, which leaves the
|
|
// point at the *end* of the redline and the mark at the start (so GetRedline
|
|
// would return NULL if called on the point)
|
|
SwDoc *pDoc = m_pWrtShell->GetDoc();
|
|
SwPaM *pCursor = m_pWrtShell->GetCrsr();
|
|
|
|
sal_uInt16 nRedline = 0;
|
|
const SwRedline *pRedline = pDoc->GetRedline(*pCursor->Start(), &nRedline);
|
|
assert(pRedline != 0);
|
|
if (pRedline)
|
|
{
|
|
if (FN_REDLINE_ACCEPT_DIRECT == nSlot)
|
|
m_pWrtShell->AcceptRedline(nRedline);
|
|
else
|
|
m_pWrtShell->RejectRedline(nRedline);
|
|
}
|
|
}
|
|
break;
|
|
|
|
case FN_REDLINE_NEXT_CHANGE:
|
|
{
|
|
const SwRedline *pCurrent = m_pWrtShell->GetCurrRedline();
|
|
const SwRedline *pNext = m_pWrtShell->SelNextRedline();
|
|
|
|
// FN_REDLINE_PREV_CHANGE leaves the selection point at the start of the redline.
|
|
// In such cases, SelNextRedline (which starts searching from the selection point)
|
|
// immediately finds the current redline and advances the selection point to its end.
|
|
//
|
|
// This behavior means that PREV_CHANGE followed by NEXT_CHANGE would not change
|
|
// the current redline, so we detect it and select the next redline again.
|
|
if (pCurrent && pCurrent == pNext)
|
|
pNext = m_pWrtShell->SelNextRedline();
|
|
|
|
if (pNext)
|
|
m_pWrtShell->SetInSelect();
|
|
}
|
|
break;
|
|
|
|
case FN_REDLINE_PREV_CHANGE:
|
|
{
|
|
const SwPaM *pCursor = m_pWrtShell->GetCrsr();
|
|
const SwPosition initialCursorStart = *pCursor->Start();
|
|
const SwRedline *pPrev = m_pWrtShell->SelPrevRedline();
|
|
|
|
if (pPrev)
|
|
{
|
|
// FN_REDLINE_NEXT_CHANGE leaves the selection point at the end of the redline.
|
|
// In such cases, SelPrevRedline (which starts searching from the selection point)
|
|
// immediately finds the current redline and advances the selection point to its
|
|
// start.
|
|
//
|
|
// This behavior means that NEXT_CHANGE followed by PREV_CHANGE would not change
|
|
// the current redline, so we detect it and move to the previous redline again.
|
|
if (initialCursorStart == *pPrev->Start())
|
|
pPrev = m_pWrtShell->SelPrevRedline();
|
|
}
|
|
|
|
if (pPrev)
|
|
m_pWrtShell->SetInSelect();
|
|
}
|
|
break;
|
|
|
|
case SID_DOCUMENT_COMPARE:
|
|
case SID_DOCUMENT_MERGE:
|
|
{
|
|
String sFileName, sFilterName;
|
|
sal_Int16 nVersion = 0;
|
|
bool bHasFileName = false;
|
|
m_pViewImpl->SetParam( 0 );
|
|
|
|
if( pArgs )
|
|
{
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_FILE_NAME, sal_False, &pItem ))
|
|
sFileName = ((const SfxStringItem*)pItem)->GetValue();
|
|
bHasFileName = ( sFileName.Len() > 0 );
|
|
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_FILTER_NAME, sal_False, &pItem ))
|
|
sFilterName = ((const SfxStringItem*)pItem)->GetValue();
|
|
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_VERSION, sal_False, &pItem ))
|
|
{
|
|
nVersion = ((const SfxInt16Item *)pItem)->GetValue();
|
|
m_pViewImpl->SetParam( nVersion );
|
|
}
|
|
}
|
|
|
|
m_pViewImpl->InitRequest( rReq );
|
|
long nFound = InsertDoc( nSlot, sFileName, sFilterName, nVersion );
|
|
|
|
if ( bHasFileName )
|
|
{
|
|
rReq.SetReturnValue( SfxInt32Item( nSlot, nFound ));
|
|
|
|
if (nFound > 0) // Redline-Browser anzeigen
|
|
{
|
|
SfxViewFrame* pVFrame = GetViewFrame();
|
|
pVFrame->ShowChildWindow(FN_REDLINE_ACCEPT);
|
|
|
|
// RedlineDlg neu initialisieren
|
|
sal_uInt16 nId = SwRedlineAcceptChild::GetChildWindowId();
|
|
SwRedlineAcceptChild *pRed = (SwRedlineAcceptChild*)
|
|
pVFrame->GetChildWindow(nId);
|
|
if (pRed)
|
|
pRed->ReInitDlg(GetDocShell());
|
|
}
|
|
}
|
|
else
|
|
bIgnore = sal_True;
|
|
}
|
|
break;
|
|
case FN_SYNC_LABELS:
|
|
case FN_MAILMERGE_CHILDWINDOW:
|
|
GetViewFrame()->ShowChildWindow(nSlot, sal_True);
|
|
break;
|
|
case FN_ESCAPE:
|
|
{
|
|
if ( m_pWrtShell->HasDrawView() && m_pWrtShell->GetDrawView()->IsDragObj() )
|
|
{
|
|
m_pWrtShell->BreakDrag();
|
|
m_pWrtShell->EnterSelFrmMode();
|
|
}
|
|
else if ( m_pWrtShell->IsDrawCreate() )
|
|
{
|
|
GetDrawFuncPtr()->BreakCreate();
|
|
AttrChangedNotify(m_pWrtShell); // ggf Shellwechsel...
|
|
}
|
|
else if ( m_pWrtShell->HasSelection() || IsDrawMode() )
|
|
{
|
|
SdrView *pSdrView = m_pWrtShell->HasDrawView() ? m_pWrtShell->GetDrawView() : 0;
|
|
if(pSdrView && pSdrView->AreObjectsMarked() &&
|
|
pSdrView->GetHdlList().GetFocusHdl())
|
|
{
|
|
((SdrHdlList&)pSdrView->GetHdlList()).ResetFocusHdl();
|
|
}
|
|
else
|
|
{
|
|
if(pSdrView)
|
|
{
|
|
LeaveDrawCreate();
|
|
Point aPt(LONG_MIN, LONG_MIN);
|
|
//go out of the frame
|
|
m_pWrtShell->SelectObj(aPt, SW_LEAVE_FRAME);
|
|
SfxBindings& rBind = GetViewFrame()->GetBindings();
|
|
rBind.Invalidate( SID_ATTR_SIZE );
|
|
}
|
|
m_pWrtShell->EnterStdMode();
|
|
AttrChangedNotify(m_pWrtShell); // ggf Shellwechsel...
|
|
}
|
|
}
|
|
else if ( GetEditWin().GetApplyTemplate() )
|
|
{
|
|
GetEditWin().SetApplyTemplate(SwApplyTemplate());
|
|
}
|
|
else if( ((SfxObjectShell*)GetDocShell())->IsInPlaceActive() )
|
|
{
|
|
Escape();
|
|
}
|
|
else if ( GetEditWin().IsChainMode() )
|
|
{
|
|
GetEditWin().SetChainMode( sal_False );
|
|
}
|
|
else if( m_pWrtShell->GetFlyFrmFmt() )
|
|
{
|
|
const SwFrmFmt* pFmt = m_pWrtShell->GetFlyFrmFmt();
|
|
if(m_pWrtShell->GotoFly( pFmt->GetName(), FLYCNTTYPE_FRM ))
|
|
{
|
|
m_pWrtShell->HideCrsr();
|
|
m_pWrtShell->EnterSelFrmMode();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
SfxBoolItem aItem( SID_WIN_FULLSCREEN, sal_False );
|
|
GetViewFrame()->GetDispatcher()->Execute( SID_WIN_FULLSCREEN, SFX_CALLMODE_RECORD, &aItem, 0L );
|
|
bIgnore = sal_True;
|
|
}
|
|
}
|
|
break;
|
|
case SID_ATTR_BORDER_INNER:
|
|
case SID_ATTR_BORDER_OUTER:
|
|
case SID_ATTR_BORDER_SHADOW:
|
|
if(pArgs)
|
|
m_pWrtShell->SetAttr(*pArgs);
|
|
break;
|
|
|
|
case SID_ATTR_PAGE:
|
|
case SID_ATTR_PAGE_SIZE:
|
|
case SID_ATTR_PAGE_MAXSIZE:
|
|
case SID_ATTR_PAGE_PAPERBIN:
|
|
case SID_ATTR_PAGE_EXT1:
|
|
case FN_PARAM_FTN_INFO:
|
|
{
|
|
if(pArgs)
|
|
{
|
|
const sal_uInt16 nCurIdx = m_pWrtShell->GetCurPageDesc();
|
|
SwPageDesc aPageDesc( m_pWrtShell->GetPageDesc( nCurIdx ) );
|
|
::ItemSetToPageDesc( *pArgs, aPageDesc );
|
|
// Den Descriptor der Core veraendern.
|
|
m_pWrtShell->ChgPageDesc( nCurIdx, aPageDesc );
|
|
}
|
|
}
|
|
break;
|
|
case FN_NAVIGATION_PI_GOTO_PAGE:
|
|
{
|
|
SfxViewFrame* pVFrame = GetViewFrame();
|
|
SfxChildWindow* pCh = pVFrame->GetChildWindow( SID_NAVIGATOR );
|
|
if(!pCh)
|
|
{
|
|
pVFrame->ToggleChildWindow( SID_NAVIGATOR );
|
|
pCh = pVFrame->GetChildWindow( SID_NAVIGATOR );
|
|
|
|
}
|
|
((SwNavigationPI*) pCh->GetContextWindow(SW_MOD()))->GotoPage();
|
|
}
|
|
break;
|
|
case FN_EDIT_CURRENT_TOX:
|
|
{
|
|
GetViewFrame()->GetDispatcher()->Execute(
|
|
FN_INSERT_MULTI_TOX, SFX_CALLMODE_ASYNCHRON);
|
|
}
|
|
break;
|
|
case FN_UPDATE_CUR_TOX:
|
|
{
|
|
const SwTOXBase* pBase = m_pWrtShell->GetCurTOX();
|
|
if(pBase)
|
|
{
|
|
m_pWrtShell->StartAction();
|
|
if(TOX_INDEX == pBase->GetType())
|
|
m_pWrtShell->ApplyAutoMark();
|
|
m_pWrtShell->UpdateTableOf( *pBase );
|
|
m_pWrtShell->EndAction();
|
|
}
|
|
}
|
|
break;
|
|
case FN_UPDATE_TOX:
|
|
{
|
|
m_pWrtShell->StartAction();
|
|
m_pWrtShell->EnterStdMode();
|
|
sal_Bool bOldCrsrInReadOnly = m_pWrtShell->IsReadOnlyAvailable();
|
|
m_pWrtShell->SetReadOnlyAvailable( sal_True );
|
|
|
|
for( sal_uInt16 i = 0; i < 2; ++i )
|
|
{
|
|
sal_uInt16 nCount = m_pWrtShell->GetTOXCount();
|
|
if( 1 == nCount )
|
|
++i;
|
|
|
|
while( m_pWrtShell->GotoPrevTOXBase() )
|
|
; // aufs erste Verzeichnis springen
|
|
|
|
// falls wir nicht mehr in einem stehen, dann zum naechsten
|
|
// springen.
|
|
const SwTOXBase* pBase = m_pWrtShell->GetCurTOX();
|
|
if( !pBase )
|
|
{
|
|
m_pWrtShell->GotoNextTOXBase();
|
|
pBase = m_pWrtShell->GetCurTOX();
|
|
}
|
|
|
|
sal_Bool bAutoMarkApplied = sal_False;
|
|
while( pBase )
|
|
{
|
|
if(TOX_INDEX == pBase->GetType() && !bAutoMarkApplied)
|
|
{
|
|
m_pWrtShell->ApplyAutoMark();
|
|
bAutoMarkApplied = sal_True;
|
|
}
|
|
// das pBase wird nur fuer die Schnittstelle
|
|
// benoetigt. Muss mal umgetstellt werden!!!
|
|
m_pWrtShell->UpdateTableOf( *pBase );
|
|
|
|
if( m_pWrtShell->GotoNextTOXBase() )
|
|
pBase = m_pWrtShell->GetCurTOX();
|
|
else
|
|
pBase = 0;
|
|
}
|
|
}
|
|
m_pWrtShell->SetReadOnlyAvailable( bOldCrsrInReadOnly );
|
|
m_pWrtShell->EndAction();
|
|
}
|
|
break;
|
|
case SID_ATTR_BRUSH:
|
|
{
|
|
if(pArgs && SFX_ITEM_SET == pArgs->GetItemState(RES_BACKGROUND, sal_False, &pItem))
|
|
{
|
|
const sal_uInt16 nCurIdx = m_pWrtShell->GetCurPageDesc();
|
|
SwPageDesc aDesc( m_pWrtShell->GetPageDesc( nCurIdx ));
|
|
SwFrmFmt& rMaster = aDesc.GetMaster();
|
|
rMaster.SetFmtAttr(*pItem);
|
|
m_pWrtShell->ChgPageDesc( nCurIdx, aDesc);
|
|
}
|
|
}
|
|
break;
|
|
case SID_CLEARHISTORY:
|
|
{
|
|
m_pWrtShell->DelAllUndoObj();
|
|
}
|
|
break;
|
|
case SID_UNDO:
|
|
{
|
|
m_pShell->ExecuteSlot(rReq);
|
|
}
|
|
break;
|
|
case FN_INSERT_CTRL:
|
|
case FN_INSERT_OBJ_CTRL:
|
|
{
|
|
if(pArgs && SFX_ITEM_SET == pArgs->GetItemState(nSlot, sal_False, &pItem))
|
|
{
|
|
sal_uInt16 nValue = ((SfxUInt16Item*)pItem)->GetValue();
|
|
switch ( nSlot )
|
|
{
|
|
case FN_INSERT_CTRL:
|
|
{
|
|
sal_Bool bWeb = 0 != PTR_CAST(SwWebView, this);
|
|
if(bWeb)
|
|
SwView::m_nWebInsertCtrlState = nValue;
|
|
else
|
|
SwView::m_nInsertCtrlState = nValue;
|
|
}
|
|
break;
|
|
case FN_INSERT_OBJ_CTRL: SwView::m_nInsertObjectCtrlState = nValue ;break;
|
|
}
|
|
|
|
}
|
|
GetViewFrame()->GetBindings().Invalidate( nSlot );
|
|
}
|
|
break;
|
|
#if defined WNT || defined UNX
|
|
case SID_TWAIN_SELECT:
|
|
case SID_TWAIN_TRANSFER:
|
|
GetViewImpl()->ExecuteScan( rReq );
|
|
break;
|
|
#endif
|
|
|
|
case SID_ATTR_DEFTABSTOP:
|
|
{
|
|
if(pArgs && SFX_ITEM_SET == pArgs->GetItemState(SID_ATTR_DEFTABSTOP, sal_False, &pItem))
|
|
{
|
|
SvxTabStopItem aDefTabs( 0, 0, SVX_TAB_ADJUST_DEFAULT, RES_PARATR_TABSTOP );
|
|
sal_uInt16 nTab = ((const SfxUInt16Item*)pItem)->GetValue();
|
|
MakeDefTabs( nTab, aDefTabs );
|
|
m_pWrtShell->SetDefault( aDefTabs );
|
|
}
|
|
}
|
|
break;
|
|
case SID_ATTR_LANGUAGE :
|
|
if(pArgs && SFX_ITEM_SET == pArgs->GetItemState(SID_ATTR_LANGUAGE, sal_False, &pItem))
|
|
{
|
|
SvxLanguageItem aLang(((SvxLanguageItem*)pItem)->GetLanguage(), RES_CHRATR_LANGUAGE);
|
|
m_pWrtShell->SetDefault( aLang );
|
|
lcl_SetAllTextToDefaultLanguage( *m_pWrtShell, RES_CHRATR_LANGUAGE );
|
|
}
|
|
break;
|
|
case SID_ATTR_CHAR_CTL_LANGUAGE:
|
|
if(pArgs && SFX_ITEM_SET == pArgs->GetItemState(RES_CHRATR_CTL_LANGUAGE, sal_False, &pItem))
|
|
{
|
|
m_pWrtShell->SetDefault( *pItem );
|
|
lcl_SetAllTextToDefaultLanguage( *m_pWrtShell, RES_CHRATR_CTL_LANGUAGE );
|
|
}
|
|
break;
|
|
case SID_ATTR_CHAR_CJK_LANGUAGE:
|
|
if(pArgs && SFX_ITEM_SET == pArgs->GetItemState(RES_CHRATR_CJK_LANGUAGE, sal_False, &pItem))
|
|
{
|
|
m_pWrtShell->SetDefault( *pItem );
|
|
lcl_SetAllTextToDefaultLanguage( *m_pWrtShell, RES_CHRATR_CJK_LANGUAGE );
|
|
}
|
|
break;
|
|
case FN_SCROLL_NEXT_PREV:
|
|
if(pArgs && pArgs->GetItemState(FN_SCROLL_NEXT_PREV, sal_False, &pItem))
|
|
{
|
|
// call the handlers of PageUp/DownButtons, only
|
|
bool* pbNext = new bool ( ((const SfxBoolItem*)pItem)->GetValue() );
|
|
// #i75416# move the execution of the search to an asynchronously called static link
|
|
Application::PostUserEvent( STATIC_LINK(this, SwView, MoveNavigationHdl), pbNext );
|
|
}
|
|
break;
|
|
case SID_JUMPTOMARK:
|
|
if( pArgs && SFX_ITEM_SET == pArgs->GetItemState(SID_JUMPTOMARK, sal_False, &pItem))
|
|
JumpToSwMark( (( const SfxStringItem*)pItem)->GetValue() );
|
|
break;
|
|
case SID_GALLERY :
|
|
GetViewFrame()->ChildWindowExecute(rReq);
|
|
break;
|
|
case SID_AVMEDIA_PLAYER :
|
|
GetViewFrame()->ChildWindowExecute(rReq);
|
|
break;
|
|
case SID_VIEW_DATA_SOURCE_BROWSER:
|
|
{
|
|
SfxViewFrame* pVFrame = GetViewFrame();
|
|
pVFrame->ChildWindowExecute(rReq);
|
|
if(pVFrame->HasChildWindow(SID_BROWSER))
|
|
{
|
|
const SwDBData& rData = GetWrtShell().GetDBDesc();
|
|
SW_MOD()->ShowDBObj(*this, rData, sal_False);
|
|
}
|
|
}
|
|
break;
|
|
case FN_INSERT_FIELD_DATA_ONLY :
|
|
{
|
|
sal_Bool bShow = sal_False;
|
|
if( pArgs &&
|
|
SFX_ITEM_SET == pArgs->GetItemState(nSlot, sal_False, &pItem ))
|
|
bShow = ((const SfxBoolItem*)pItem)->GetValue();
|
|
if((bShow && m_bInMailMerge) != GetViewFrame()->HasChildWindow(nSlot))
|
|
GetViewFrame()->ToggleChildWindow(nSlot);
|
|
//if fields have been successfully inserted call the "real"
|
|
//mail merge dialog
|
|
SwWrtShell &rSh = GetWrtShell();
|
|
if(m_bInMailMerge && rSh.IsAnyDatabaseFieldInDoc())
|
|
{
|
|
SwNewDBMgr* pNewDBMgr = rSh.GetNewDBMgr();
|
|
if (pNewDBMgr)
|
|
{
|
|
SwDBData aData;
|
|
aData = rSh.GetDBData();
|
|
rSh.EnterStdMode(); // Wechsel in Textshell erzwingen; ist fuer
|
|
// das Mischen von DB-Feldern notwendig.
|
|
AttrChangedNotify( &rSh );
|
|
pNewDBMgr->SetMergeType( DBMGR_MERGE );
|
|
|
|
Sequence<PropertyValue> aProperties(3);
|
|
PropertyValue* pValues = aProperties.getArray();
|
|
pValues[0].Name = "DataSourceName";
|
|
pValues[1].Name = "Command";
|
|
pValues[2].Name = "CommandType";
|
|
pValues[0].Value <<= aData.sDataSource;
|
|
pValues[1].Value <<= aData.sCommand;
|
|
pValues[2].Value <<= aData.nCommandType;
|
|
pNewDBMgr->ExecuteFormLetter(rSh, aProperties, sal_True);
|
|
}
|
|
}
|
|
m_bInMailMerge &= bShow;
|
|
GetViewFrame()->GetBindings().Invalidate(FN_INSERT_FIELD);
|
|
}
|
|
break;
|
|
case FN_QRY_MERGE:
|
|
{
|
|
sal_Bool bUseCurrentDocument = sal_True;
|
|
sal_Bool bQuery = !pArgs||SFX_ITEM_SET != pArgs->GetItemState(nSlot);
|
|
if(bQuery)
|
|
{
|
|
SfxViewFrame* pTmpFrame = GetViewFrame();
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
|
|
OSL_ENSURE(pFact, "Dialogdiet fail!");
|
|
AbstractMailMergeCreateFromDlg* pDlg = pFact->CreateMailMergeCreateFromDlg(&pTmpFrame->GetWindow());
|
|
OSL_ENSURE(pDlg, "Dialogdiet fail!");
|
|
if(RET_OK == pDlg->Execute())
|
|
bUseCurrentDocument = pDlg->IsThisDocument();
|
|
else
|
|
break;
|
|
}
|
|
GenerateFormLetter(bUseCurrentDocument);
|
|
}
|
|
break;
|
|
case SID_RECHECK_DOCUMENT:
|
|
{
|
|
SwDocShell* pDocShell = GetDocShell();
|
|
SwDoc* pDoc = pDocShell->GetDoc();
|
|
uno::Reference< linguistic2::XProofreadingIterator > xGCIterator( pDoc->GetGCIterator() );
|
|
if( xGCIterator.is() )
|
|
{
|
|
xGCIterator->resetIgnoreRules();
|
|
}
|
|
// reset ignore lists
|
|
pDoc->SpellItAgainSam( true, false, false );
|
|
// clear ignore dictionary
|
|
uno::Reference< linguistic2::XDictionary > xDictionary( SvxGetIgnoreAllList(), uno::UNO_QUERY );
|
|
if( xDictionary.is() )
|
|
xDictionary->clear();
|
|
// put cursor to the start of the document
|
|
m_pWrtShell->SttDoc();
|
|
}
|
|
// no break; - but call spell/grammar dialog
|
|
case FN_SPELL_GRAMMAR_DIALOG:
|
|
{
|
|
SfxViewFrame* pViewFrame = GetViewFrame();
|
|
if (rReq.GetArgs() != NULL)
|
|
pViewFrame->SetChildWindow (FN_SPELL_GRAMMAR_DIALOG,
|
|
((const SfxBoolItem&) (rReq.GetArgs()->
|
|
Get(FN_SPELL_GRAMMAR_DIALOG))).GetValue());
|
|
else
|
|
pViewFrame->ToggleChildWindow(FN_SPELL_GRAMMAR_DIALOG);
|
|
|
|
pViewFrame->GetBindings().Invalidate(FN_SPELL_GRAMMAR_DIALOG);
|
|
rReq.Ignore ();
|
|
}
|
|
break;
|
|
case SID_ALIGN_ANY_LEFT :
|
|
case SID_ALIGN_ANY_HCENTER :
|
|
case SID_ALIGN_ANY_RIGHT :
|
|
case SID_ALIGN_ANY_JUSTIFIED:
|
|
case SID_ALIGN_ANY_TOP :
|
|
case SID_ALIGN_ANY_VCENTER :
|
|
case SID_ALIGN_ANY_BOTTOM :
|
|
case SID_ALIGN_ANY_HDEFAULT :
|
|
case SID_ALIGN_ANY_VDEFAULT :
|
|
{
|
|
sal_uInt16 nAlias = 0;
|
|
if( m_nSelectionType & (nsSelectionType::SEL_DRW_TXT|nsSelectionType::SEL_TXT) )
|
|
{
|
|
switch( nSlot )
|
|
{
|
|
case SID_ALIGN_ANY_LEFT : nAlias = SID_ATTR_PARA_ADJUST_LEFT; break;
|
|
case SID_ALIGN_ANY_HCENTER : nAlias = SID_ATTR_PARA_ADJUST_CENTER; break;
|
|
case SID_ALIGN_ANY_RIGHT : nAlias = SID_ATTR_PARA_ADJUST_RIGHT; break;
|
|
case SID_ALIGN_ANY_JUSTIFIED: nAlias = SID_ATTR_PARA_ADJUST_BLOCK; break;
|
|
case SID_ALIGN_ANY_TOP : nAlias = SID_TABLE_VERT_NONE; break;
|
|
case SID_ALIGN_ANY_VCENTER : nAlias = SID_TABLE_VERT_CENTER; break;
|
|
case SID_ALIGN_ANY_BOTTOM : nAlias = SID_TABLE_VERT_BOTTOM; break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
switch( nSlot )
|
|
{
|
|
case SID_ALIGN_ANY_LEFT : nAlias = SID_OBJECT_ALIGN_LEFT ; break;
|
|
case SID_ALIGN_ANY_HCENTER : nAlias = SID_OBJECT_ALIGN_CENTER ; break;
|
|
case SID_ALIGN_ANY_RIGHT : nAlias = SID_OBJECT_ALIGN_RIGHT ; break;
|
|
case SID_ALIGN_ANY_TOP : nAlias = SID_OBJECT_ALIGN_UP ; break;
|
|
case SID_ALIGN_ANY_VCENTER : nAlias = SID_OBJECT_ALIGN_MIDDLE ; break;
|
|
case SID_ALIGN_ANY_BOTTOM : nAlias = SID_OBJECT_ALIGN_DOWN ; break;
|
|
}
|
|
}
|
|
//special handling for the draw shell
|
|
if(nAlias && (m_nSelectionType & (nsSelectionType::SEL_DRW)))
|
|
{
|
|
SfxAllEnumItem aEnumItem(SID_OBJECT_ALIGN, nAlias - SID_OBJECT_ALIGN_LEFT);
|
|
GetViewFrame()->GetDispatcher()->Execute(
|
|
SID_OBJECT_ALIGN, SFX_CALLMODE_ASYNCHRON, &aEnumItem, 0L);
|
|
}
|
|
else if(nAlias)
|
|
//these slots are either re-mapped to text or object alignment
|
|
GetViewFrame()->GetDispatcher()->Execute(
|
|
nAlias, SFX_CALLMODE_ASYNCHRON);
|
|
}
|
|
break;
|
|
case SID_RESTORE_EDITING_VIEW:
|
|
{
|
|
//#i33307# restore editing position
|
|
Point aCrsrPos;
|
|
bool bSelectObj;
|
|
if(m_pViewImpl->GetRestorePosition(aCrsrPos, bSelectObj))
|
|
{
|
|
m_pWrtShell->SwCrsrShell::SetCrsr( aCrsrPos, !bSelectObj );
|
|
if( bSelectObj )
|
|
{
|
|
m_pWrtShell->SelectObj( aCrsrPos );
|
|
m_pWrtShell->EnterSelFrmMode( &aCrsrPos );
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
case SID_INSERT_GRAPHIC:
|
|
{
|
|
rReq.SetReturnValue(SfxBoolItem(nSlot, InsertGraphicDlg( rReq )));
|
|
}
|
|
break;
|
|
|
|
|
|
default:
|
|
OSL_ENSURE(!this, "wrong dispatcher");
|
|
return;
|
|
}
|
|
if(!bIgnore)
|
|
rReq.Done();
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: SeitenNr-Feld invalidieren
|
|
--------------------------------------------------------------------*/
|
|
void SwView::UpdatePageNums(sal_uInt16 nPhyNum, sal_uInt16 nVirtNum, const String& rPgStr)
|
|
{
|
|
String sTemp(GetPageStr( nPhyNum, nVirtNum, rPgStr ));
|
|
const SfxStringItem aTmp( FN_STAT_PAGE, sTemp );
|
|
SfxBindings &rBnd = GetViewFrame()->GetBindings();
|
|
rBnd.SetState( aTmp );
|
|
rBnd.Update( FN_STAT_PAGE );
|
|
}
|
|
|
|
void SwView::UpdateDocStats()
|
|
{
|
|
SfxBindings &rBnd = GetViewFrame()->GetBindings();
|
|
rBnd.Invalidate( FN_STAT_WORDCOUNT );
|
|
rBnd.Update( FN_STAT_WORDCOUNT );
|
|
}
|
|
|
|
void SwView::SetAnnotationMode(bool bMode)
|
|
{
|
|
m_bAnnotationMode = bMode;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Status der Stauszeile
|
|
--------------------------------------------------------------------*/
|
|
void SwView::StateStatusLine(SfxItemSet &rSet)
|
|
{
|
|
SwWrtShell& rShell = GetWrtShell();
|
|
|
|
SfxWhichIter aIter( rSet );
|
|
sal_uInt16 nWhich = aIter.FirstWhich();
|
|
OSL_ENSURE( nWhich, "empty set");
|
|
|
|
while( nWhich )
|
|
{
|
|
switch( nWhich )
|
|
{
|
|
case FN_STAT_PAGE: {
|
|
// Anzahl der Seiten, log. SeitenNr. SeitenNr ermitteln
|
|
sal_uInt16 nPage, nLogPage;
|
|
String sDisplay;
|
|
rShell.GetPageNumber( -1, rShell.IsCrsrVisible(), nPage, nLogPage, sDisplay );
|
|
rSet.Put( SfxStringItem( FN_STAT_PAGE,
|
|
GetPageStr( nPage, nLogPage, sDisplay) ));
|
|
|
|
sal_uInt16 nCnt = GetWrtShell().GetPageCnt();
|
|
if (m_nPageCnt != nCnt) // Basic benachrichtigen
|
|
{
|
|
m_nPageCnt = nCnt;
|
|
SFX_APP()->NotifyEvent(SfxEventHint(SW_EVENT_PAGE_COUNT, SwDocShell::GetEventName(STR_SW_EVENT_PAGE_COUNT), GetViewFrame()->GetObjectShell()), sal_False);
|
|
}
|
|
}
|
|
break;
|
|
|
|
case FN_STAT_WORDCOUNT:
|
|
{
|
|
SwDocStat selectionStats;
|
|
SwDocStat documentStats;
|
|
{
|
|
rShell.CountWords(selectionStats);
|
|
documentStats = rShell.GetDoc()->GetUpdatedDocStat( true /* complete-async */, false /* don't update fields */ );
|
|
}
|
|
|
|
const sal_uInt32 stringId = selectionStats.nWord? STR_STATUSBAR_WORDCOUNT : STR_STATUSBAR_WORDCOUNT_NO_SELECTION;
|
|
OUString wordCount(SW_RES(stringId));
|
|
wordCount = wordCount.replaceAll("$1", OUString::number(documentStats.nWord));
|
|
wordCount = wordCount.replaceAll("$2", OUString::number(documentStats.nChar));
|
|
if (selectionStats.nWord)
|
|
{
|
|
wordCount = wordCount.replaceAll("$3", OUString::number(selectionStats.nWord));
|
|
wordCount = wordCount.replaceAll("$4", OUString::number(selectionStats.nChar));
|
|
}
|
|
rSet.Put(SfxStringItem(FN_STAT_WORDCOUNT, wordCount));
|
|
|
|
SwWordCountWrapper *pWrdCnt = (SwWordCountWrapper*)GetViewFrame()->GetChildWindow(SwWordCountWrapper::GetChildWindowId());
|
|
if (pWrdCnt)
|
|
pWrdCnt->SetCounts(selectionStats, documentStats);
|
|
}
|
|
break;
|
|
|
|
case FN_STAT_TEMPLATE:
|
|
{
|
|
rSet.Put(SfxStringItem( FN_STAT_TEMPLATE,
|
|
rShell.GetCurPageStyle(sal_False)));
|
|
|
|
}
|
|
break;
|
|
case SID_ATTR_ZOOM:
|
|
{
|
|
if ( ( GetDocShell()->GetCreateMode() != SFX_CREATE_MODE_EMBEDDED ) || !GetDocShell()->IsInPlaceActive() )
|
|
{
|
|
const SwViewOption* pVOpt = rShell.GetViewOptions();
|
|
SvxZoomType eZoom = (SvxZoomType) pVOpt->GetZoomType();
|
|
SvxZoomItem aZoom(eZoom,
|
|
pVOpt->GetZoom());
|
|
if( pVOpt->getBrowseMode() )
|
|
{
|
|
aZoom.SetValueSet(
|
|
SVX_ZOOM_ENABLE_50|
|
|
SVX_ZOOM_ENABLE_75|
|
|
SVX_ZOOM_ENABLE_100|
|
|
SVX_ZOOM_ENABLE_150|
|
|
SVX_ZOOM_ENABLE_200);
|
|
}
|
|
rSet.Put( aZoom );
|
|
}
|
|
else
|
|
rSet.DisableItem( SID_ATTR_ZOOM );
|
|
}
|
|
break;
|
|
case SID_ATTR_VIEWLAYOUT:
|
|
{
|
|
if ( ( GetDocShell()->GetCreateMode() != SFX_CREATE_MODE_EMBEDDED ) || !GetDocShell()->IsInPlaceActive() )
|
|
{
|
|
const SwViewOption* pVOpt = rShell.GetViewOptions();
|
|
const sal_uInt16 nColumns = pVOpt->GetViewLayoutColumns();
|
|
const bool bBookMode = pVOpt->IsViewLayoutBookMode();
|
|
SvxViewLayoutItem aViewLayout(nColumns, bBookMode);
|
|
rSet.Put( aViewLayout );
|
|
}
|
|
else
|
|
rSet.DisableItem( SID_ATTR_VIEWLAYOUT );
|
|
}
|
|
break;
|
|
case SID_ATTR_ZOOMSLIDER:
|
|
{
|
|
if ( ( GetDocShell()->GetCreateMode() != SFX_CREATE_MODE_EMBEDDED ) || !GetDocShell()->IsInPlaceActive() )
|
|
{
|
|
const SwViewOption* pVOpt = rShell.GetViewOptions();
|
|
const sal_uInt16 nCurrentZoom = pVOpt->GetZoom();
|
|
SvxZoomSliderItem aZoomSliderItem( nCurrentZoom, MINZOOM, MAXZOOM );
|
|
aZoomSliderItem.AddSnappingPoint( 100 );
|
|
|
|
if ( !m_pWrtShell->getIDocumentSettingAccess()->get(IDocumentSettingAccess::BROWSE_MODE) )
|
|
{
|
|
const sal_uInt16 nColumns = pVOpt->GetViewLayoutColumns();
|
|
const bool bAutomaticViewLayout = 0 == nColumns;
|
|
const SwPostItMgr* pMgr = GetPostItMgr();
|
|
|
|
// snapping points:
|
|
// automatic mode: 1 Page, 2 Pages, 100%
|
|
// n Columns mode: n Pages, 100%
|
|
// n Columns book mode: nPages without gaps, 100%
|
|
const SwRect aPageRect( m_pWrtShell->GetAnyCurRect( RECT_PAGE_CALC ) );
|
|
const SwRect aRootRect( m_pWrtShell->GetAnyCurRect( RECT_PAGES_AREA ) ); // width of columns
|
|
Size aPageSize( aPageRect.SSize() );
|
|
aPageSize.Width() += pMgr->HasNotes() && pMgr->ShowNotes() ?
|
|
pMgr->GetSidebarWidth() + pMgr->GetSidebarBorderWidth() :
|
|
0;
|
|
|
|
Size aRootSize( aRootRect.SSize() );
|
|
|
|
const MapMode aTmpMap( MAP_TWIP );
|
|
const Size& rEditSize = GetEditWin().GetOutputSizePixel();
|
|
const Size aWindowSize( GetEditWin().PixelToLogic( rEditSize, aTmpMap ) );
|
|
|
|
const long nOf = DOCUMENTBORDER * 2L;
|
|
long nTmpWidth = bAutomaticViewLayout ? aPageSize.Width() : aRootSize.Width();
|
|
nTmpWidth += nOf;
|
|
aPageSize.Height() += nOf;
|
|
long nFac = aWindowSize.Width() * 100 / nTmpWidth;
|
|
|
|
long nVisPercent = aWindowSize.Height() * 100 / aPageSize.Height();
|
|
nFac = std::min( nFac, nVisPercent );
|
|
|
|
aZoomSliderItem.AddSnappingPoint( nFac );
|
|
|
|
if ( bAutomaticViewLayout )
|
|
{
|
|
nTmpWidth += aPageSize.Width() + GAPBETWEENPAGES;
|
|
nFac = aWindowSize.Width() * 100 / nTmpWidth;
|
|
nFac = std::min( nFac, nVisPercent );
|
|
aZoomSliderItem.AddSnappingPoint( nFac );
|
|
}
|
|
}
|
|
|
|
rSet.Put( aZoomSliderItem );
|
|
}
|
|
else
|
|
rSet.DisableItem( SID_ATTR_ZOOMSLIDER );
|
|
}
|
|
break;
|
|
case SID_ATTR_POSITION:
|
|
case SID_ATTR_SIZE:
|
|
{
|
|
if( !rShell.IsFrmSelected() && !rShell.IsObjSelected() )
|
|
SwBaseShell::_SetFrmMode( FLY_DRAG_END );
|
|
else
|
|
{
|
|
FlyMode eFrameMode = SwBaseShell::GetFrmMode();
|
|
if ( eFrameMode == FLY_DRAG_START || eFrameMode == FLY_DRAG )
|
|
{
|
|
if ( nWhich == SID_ATTR_POSITION )
|
|
rSet.Put( SfxPointItem( SID_ATTR_POSITION,
|
|
rShell.GetAnchorObjDiff()));
|
|
else
|
|
rSet.Put( SvxSizeItem( SID_ATTR_SIZE,
|
|
rShell.GetObjSize()));
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
case SID_TABLE_CELL:
|
|
|
|
if( rShell.IsFrmSelected() || rShell.IsObjSelected() )
|
|
{
|
|
// #i39171# Don't put a SvxSizeItem into a slot which is defined as SfxStringItem.
|
|
// SvxPosSizeStatusBarControl no longer resets to empty display if only one slot
|
|
// has no item, so SID_TABLE_CELL can remain empty (the SvxSizeItem is supplied
|
|
// in SID_ATTR_SIZE).
|
|
}
|
|
else
|
|
{
|
|
String sStr;
|
|
if( rShell.IsCrsrInTbl() )
|
|
{
|
|
// table name + cell coordinate
|
|
sStr = rShell.GetTableFmt()->GetName();
|
|
sStr += ':';
|
|
sStr += rShell.GetBoxNms();
|
|
}
|
|
else
|
|
{
|
|
const SwSection* pCurrSect = rShell.GetCurrSection();
|
|
if( pCurrSect )
|
|
{
|
|
switch( pCurrSect->GetType() )
|
|
{
|
|
case TOX_HEADER_SECTION:
|
|
case TOX_CONTENT_SECTION:
|
|
{
|
|
const SwTOXBase* pTOX = m_pWrtShell->GetCurTOX();
|
|
if( pTOX )
|
|
sStr = pTOX->GetTOXName();
|
|
else
|
|
{
|
|
OSL_ENSURE( !this,
|
|
"was ist das fuer ein Verzeichnis?" );
|
|
sStr = pCurrSect->GetSectionName();
|
|
}
|
|
}
|
|
break;
|
|
default:
|
|
sStr = pCurrSect->GetSectionName();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
//-->#outline level,added by zhaojianwei
|
|
const SwNumRule* pNumRule = rShell.GetCurNumRule();
|
|
const bool bOutlineNum = pNumRule ? pNumRule->IsOutlineRule() : 0;
|
|
|
|
if (pNumRule && !bOutlineNum ) // Cursor in Numerierung
|
|
{
|
|
sal_uInt8 nNumLevel = rShell.GetNumLevel();
|
|
if ( nNumLevel < MAXLEVEL )
|
|
{
|
|
if(!pNumRule->IsAutoRule())
|
|
{
|
|
SfxItemSet aSet(GetPool(),
|
|
RES_PARATR_NUMRULE, RES_PARATR_NUMRULE);
|
|
rShell.GetCurAttr(aSet);
|
|
if(SFX_ITEM_AVAILABLE <=
|
|
aSet.GetItemState(RES_PARATR_NUMRULE, sal_True))
|
|
{
|
|
const String& rNumStyle =
|
|
((const SfxStringItem &)
|
|
aSet.Get(RES_PARATR_NUMRULE)).GetValue();
|
|
if(rNumStyle.Len())
|
|
{
|
|
if( sStr.Len() )
|
|
sStr.AppendAscii(sStatusDelim);
|
|
sStr += rNumStyle;
|
|
}
|
|
}
|
|
}
|
|
if( sStr.Len() )
|
|
sStr.AppendAscii(sStatusDelim);
|
|
sStr += SW_RESSTR(STR_NUM_LEVEL);
|
|
sStr += OUString::number( nNumLevel + 1 );
|
|
|
|
}
|
|
}
|
|
const int nOutlineLevel = rShell.GetCurrentParaOutlineLevel();
|
|
if( nOutlineLevel != 0 )
|
|
{
|
|
if( sStr.Len() )
|
|
sStr.AppendAscii(sStatusComma);
|
|
if( bOutlineNum )
|
|
{
|
|
sStr += SW_RESSTR(STR_OUTLINE_NUMBERING);
|
|
sStr.AppendAscii(sStatusDelim);
|
|
sStr += SW_RESSTR(STR_NUM_LEVEL);
|
|
}
|
|
else
|
|
sStr += SW_RESSTR(STR_NUM_OUTLINE);
|
|
sStr += OUString::number( nOutlineLevel);
|
|
}
|
|
//<-end ,zhaojianwei
|
|
|
|
if( rShell.HasReadonlySel() )
|
|
{
|
|
if( sStr.Len() )
|
|
sStr.InsertAscii( sStatusDelim, 0 );
|
|
sStr.Insert( SW_RESSTR(SW_STR_READONLY), 0 );
|
|
}
|
|
if( sStr.Len() )
|
|
rSet.Put( SfxStringItem( SID_TABLE_CELL, sStr ));
|
|
}
|
|
break;
|
|
case FN_STAT_SELMODE:
|
|
{
|
|
if(rShell.IsStdMode())
|
|
rSet.Put(SfxUInt16Item(FN_STAT_SELMODE, 0));
|
|
else if(rShell.IsAddMode())
|
|
rSet.Put(SfxUInt16Item(FN_STAT_SELMODE, 2));
|
|
else if(rShell.IsBlockMode())
|
|
rSet.Put(SfxUInt16Item(FN_STAT_SELMODE, 3));
|
|
else
|
|
rSet.Put(SfxUInt16Item(FN_STAT_SELMODE, 1));
|
|
break;
|
|
}
|
|
case SID_ATTR_INSERT:
|
|
if( rShell.IsRedlineOn() )
|
|
rSet.DisableItem( nWhich );
|
|
else
|
|
{
|
|
rSet.Put(SfxBoolItem(SID_ATTR_INSERT,rShell.IsInsMode()));
|
|
}
|
|
break;
|
|
}
|
|
nWhich = aIter.NextWhich();
|
|
}
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Execute fuer die Stauszeile
|
|
--------------------------------------------------------------------*/
|
|
void SwView::ExecuteStatusLine(SfxRequest &rReq)
|
|
{
|
|
SwWrtShell &rSh = GetWrtShell();
|
|
const SfxItemSet* pArgs = rReq.GetArgs();
|
|
const SfxPoolItem* pItem=NULL;
|
|
sal_Bool bUp = sal_False;
|
|
sal_uInt16 nWhich = rReq.GetSlot();
|
|
switch( nWhich )
|
|
{
|
|
case FN_STAT_PAGE:
|
|
{
|
|
GetViewFrame()->GetDispatcher()->Execute( SID_NAVIGATOR,
|
|
SFX_CALLMODE_SYNCHRON|SFX_CALLMODE_RECORD );
|
|
}
|
|
break;
|
|
|
|
case FN_STAT_WORDCOUNT:
|
|
{
|
|
GetViewFrame()->GetDispatcher()->Execute(FN_WORDCOUNT_DIALOG,
|
|
SFX_CALLMODE_SYNCHRON|SFX_CALLMODE_RECORD );
|
|
}
|
|
break;
|
|
|
|
case FN_STAT_BOOKMARK:
|
|
if ( pArgs )
|
|
{
|
|
if (SFX_ITEM_SET == pArgs->GetItemState( nWhich, sal_True, &pItem))
|
|
{
|
|
const IDocumentMarkAccess* pMarkAccess = rSh.getIDocumentMarkAccess();
|
|
const sal_Int32 nIdx = static_cast<const SfxUInt16Item*>(pItem)->GetValue();
|
|
if(nIdx < pMarkAccess->getBookmarksCount())
|
|
{
|
|
const IDocumentMarkAccess::const_iterator_t ppBookmark = rSh.getIDocumentMarkAccess()->getBookmarksBegin() + nIdx;
|
|
rSh.EnterStdMode();
|
|
rSh.GotoMark( ppBookmark->get() );
|
|
}
|
|
else
|
|
OSL_FAIL("SwView::ExecuteStatusLine(..)"
|
|
" - Ignoring out of range bookmark index");
|
|
}
|
|
}
|
|
break;
|
|
|
|
case FN_STAT_TEMPLATE:
|
|
{
|
|
GetViewFrame()->GetDispatcher()->Execute(FN_FORMAT_PAGE_DLG,
|
|
SFX_CALLMODE_SYNCHRON|SFX_CALLMODE_RECORD );
|
|
}
|
|
break;
|
|
case SID_ATTR_ZOOM:
|
|
{
|
|
if ( ( GetDocShell()->GetCreateMode() != SFX_CREATE_MODE_EMBEDDED ) || !GetDocShell()->IsInPlaceActive() )
|
|
{
|
|
const SfxItemSet *pSet = 0;
|
|
AbstractSvxZoomDialog *pDlg = 0;
|
|
if ( pArgs )
|
|
pSet = pArgs;
|
|
else
|
|
{
|
|
const SwViewOption& rViewOptions = *rSh.GetViewOptions();
|
|
SfxItemSet aCoreSet(m_pShell->GetPool(), SID_ATTR_ZOOM, SID_ATTR_ZOOM, SID_ATTR_VIEWLAYOUT, SID_ATTR_VIEWLAYOUT, 0 );
|
|
SvxZoomItem aZoom( (SvxZoomType)rViewOptions.GetZoomType(), rViewOptions.GetZoom() );
|
|
|
|
const bool bBrowseMode = rSh.GetViewOptions()->getBrowseMode();
|
|
if( bBrowseMode )
|
|
{
|
|
aZoom.SetValueSet(
|
|
SVX_ZOOM_ENABLE_50|
|
|
SVX_ZOOM_ENABLE_75|
|
|
SVX_ZOOM_ENABLE_100|
|
|
SVX_ZOOM_ENABLE_150|
|
|
SVX_ZOOM_ENABLE_200);
|
|
}
|
|
aCoreSet.Put( aZoom );
|
|
|
|
if ( !bBrowseMode )
|
|
{
|
|
const SvxViewLayoutItem aViewLayout( rViewOptions.GetViewLayoutColumns(), rViewOptions.IsViewLayoutBookMode() );
|
|
aCoreSet.Put( aViewLayout );
|
|
}
|
|
|
|
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
|
|
if(pFact)
|
|
{
|
|
pDlg = pFact->CreateSvxZoomDialog(&GetViewFrame()->GetWindow(), aCoreSet);
|
|
OSL_ENSURE(pDlg, "Dialogdiet fail!");
|
|
if (pDlg)
|
|
{
|
|
pDlg->SetLimits( MINZOOM, MAXZOOM );
|
|
if( pDlg->Execute() != RET_CANCEL )
|
|
pSet = pDlg->GetOutputItemSet();
|
|
}
|
|
}
|
|
}
|
|
|
|
const SfxPoolItem* pViewLayoutItem = 0;
|
|
if ( pSet && SFX_ITEM_SET == pSet->GetItemState(SID_ATTR_VIEWLAYOUT, sal_True, &pViewLayoutItem))
|
|
{
|
|
const sal_uInt16 nColumns = ((const SvxViewLayoutItem *)pViewLayoutItem)->GetValue();
|
|
const bool bBookMode = ((const SvxViewLayoutItem *)pViewLayoutItem)->IsBookMode();
|
|
SetViewLayout( nColumns, bBookMode );
|
|
}
|
|
|
|
if ( pSet && SFX_ITEM_SET == pSet->GetItemState(SID_ATTR_ZOOM, sal_True, &pItem))
|
|
{
|
|
enum SvxZoomType eType = ((const SvxZoomItem *)pItem)->GetType();
|
|
SetZoom( eType, ((const SvxZoomItem *)pItem)->GetValue() );
|
|
}
|
|
bUp = sal_True;
|
|
if ( pItem )
|
|
rReq.AppendItem( *pItem );
|
|
rReq.Done();
|
|
|
|
delete pDlg;
|
|
}
|
|
}
|
|
break;
|
|
|
|
case SID_ATTR_VIEWLAYOUT:
|
|
{
|
|
if ( pArgs && !rSh.getIDocumentSettingAccess()->get(IDocumentSettingAccess::BROWSE_MODE) &&
|
|
( ( GetDocShell()->GetCreateMode() != SFX_CREATE_MODE_EMBEDDED ) || !GetDocShell()->IsInPlaceActive() ) )
|
|
{
|
|
if ( SFX_ITEM_SET == pArgs->GetItemState(SID_ATTR_VIEWLAYOUT, sal_True, &pItem ))
|
|
{
|
|
const sal_uInt16 nColumns = ((const SvxViewLayoutItem *)pItem)->GetValue();
|
|
const bool bBookMode = (0 == nColumns || 0 != (nColumns % 2)) ?
|
|
false :
|
|
((const SvxViewLayoutItem *)pItem)->IsBookMode();
|
|
|
|
SetViewLayout( nColumns, bBookMode );
|
|
}
|
|
|
|
bUp = sal_True;
|
|
rReq.Done();
|
|
|
|
InvalidateRulerPos();
|
|
}
|
|
}
|
|
break;
|
|
|
|
case SID_ATTR_ZOOMSLIDER:
|
|
{
|
|
if ( pArgs && ( ( GetDocShell()->GetCreateMode() != SFX_CREATE_MODE_EMBEDDED ) || !GetDocShell()->IsInPlaceActive() ) )
|
|
{
|
|
if ( SFX_ITEM_SET == pArgs->GetItemState(SID_ATTR_ZOOMSLIDER, sal_True, &pItem ))
|
|
{
|
|
const sal_uInt16 nCurrentZoom = ((const SvxZoomSliderItem *)pItem)->GetValue();
|
|
SetZoom( SVX_ZOOM_PERCENT, nCurrentZoom );
|
|
}
|
|
|
|
bUp = sal_True;
|
|
rReq.Done();
|
|
}
|
|
}
|
|
break;
|
|
|
|
case SID_ATTR_SIZE:
|
|
{
|
|
sal_uLong nId = FN_INSERT_FIELD;
|
|
if( rSh.IsCrsrInTbl() )
|
|
nId = FN_FORMAT_TABLE_DLG;
|
|
else if( rSh.GetCurTOX() )
|
|
nId = FN_INSERT_MULTI_TOX;
|
|
else if( rSh.GetCurrSection() )
|
|
nId = FN_EDIT_REGION;
|
|
else
|
|
{
|
|
const SwNumRule* pNumRule = rSh.GetCurNumRule();
|
|
if( pNumRule ) // Cursor in Numerierung
|
|
{
|
|
if( pNumRule->IsAutoRule() )
|
|
nId = FN_NUMBER_BULLETS;
|
|
else
|
|
{
|
|
// Dialog vom Gestalter starten ;-)
|
|
nId = 0;
|
|
}
|
|
}
|
|
else if( rSh.IsFrmSelected() )
|
|
nId = FN_FORMAT_FRAME_DLG;
|
|
else if( rSh.IsObjSelected() )
|
|
nId = SID_ATTR_TRANSFORM;
|
|
}
|
|
if( nId )
|
|
GetViewFrame()->GetDispatcher()->Execute(
|
|
static_cast< sal_uInt16 >( nId ), SFX_CALLMODE_SYNCHRON | SFX_CALLMODE_RECORD );
|
|
}
|
|
break;
|
|
|
|
case FN_STAT_SELMODE:
|
|
{
|
|
if ( pArgs )
|
|
{
|
|
if (SFX_ITEM_SET == pArgs->GetItemState( nWhich, sal_True, &pItem))
|
|
{
|
|
switch ( ((const SfxUInt16Item *)pItem)->GetValue() )
|
|
{
|
|
case 0: rSh.EnterStdMode(); break;
|
|
case 1: rSh.EnterExtMode(); break;
|
|
case 2: rSh.EnterAddMode(); break;
|
|
case 3: rSh.EnterBlockMode(); break;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
if( !rSh.IsAddMode() && !rSh.IsExtMode() && !rSh.IsBlockMode() )
|
|
rSh.ToggleExtMode();
|
|
else if ( rSh.IsExtMode() )
|
|
{
|
|
rSh.ToggleExtMode();
|
|
rSh.ToggleAddMode();
|
|
}
|
|
else if ( rSh.IsAddMode() )
|
|
{
|
|
rSh.ToggleAddMode();
|
|
rSh.ToggleBlockMode();
|
|
}
|
|
else
|
|
rSh.ToggleBlockMode();
|
|
}
|
|
bUp = sal_True;
|
|
break;
|
|
}
|
|
case FN_SET_ADD_MODE:
|
|
rSh.ToggleAddMode();
|
|
nWhich = FN_STAT_SELMODE;
|
|
bUp = sal_True;
|
|
break;
|
|
case FN_SET_BLOCK_MODE:
|
|
rSh.ToggleBlockMode();
|
|
nWhich = FN_STAT_SELMODE;
|
|
bUp = sal_True;
|
|
break;
|
|
case FN_SET_EXT_MODE:
|
|
rSh.ToggleExtMode();
|
|
nWhich = FN_STAT_SELMODE;
|
|
bUp = sal_True;
|
|
break;
|
|
case SID_ATTR_INSERT:
|
|
SwPostItMgr* pMgr = GetPostItMgr();
|
|
if ( pMgr && pMgr->HasActiveSidebarWin() )
|
|
{
|
|
pMgr->ToggleInsModeOnActiveSidebarWin();
|
|
}
|
|
else
|
|
rSh.ToggleInsMode();
|
|
bUp = sal_True;
|
|
break;
|
|
|
|
}
|
|
if ( bUp )
|
|
{
|
|
SfxBindings &rBnd = GetViewFrame()->GetBindings();
|
|
rBnd.Invalidate(nWhich);
|
|
rBnd.Update(nWhich);
|
|
}
|
|
}
|
|
|
|
void SwView::InsFrmMode(sal_uInt16 nCols)
|
|
{
|
|
if ( m_pWrtShell->HasWholeTabSelection() )
|
|
{
|
|
SwFlyFrmAttrMgr aMgr( sal_True, m_pWrtShell, FRMMGR_TYPE_TEXT );
|
|
|
|
const SwFrmFmt &rPageFmt =
|
|
m_pWrtShell->GetPageDesc(m_pWrtShell->GetCurPageDesc()).GetMaster();
|
|
SwTwips lWidth = rPageFmt.GetFrmSize().GetWidth();
|
|
const SvxLRSpaceItem &rLR = rPageFmt.GetLRSpace();
|
|
lWidth -= rLR.GetLeft() + rLR.GetRight();
|
|
aMgr.SetSize(Size(lWidth, aMgr.GetSize().Height()));
|
|
if(nCols > 1)
|
|
{
|
|
SwFmtCol aCol;
|
|
aCol.Init( nCols, aCol.GetGutterWidth(), aCol.GetWishWidth() );
|
|
aMgr.SetCol( aCol );
|
|
}
|
|
aMgr.InsertFlyFrm();
|
|
}
|
|
else
|
|
GetEditWin().InsFrm(nCols);
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Links bearbeiten
|
|
--------------------------------------------------------------------*/
|
|
void SwView::EditLinkDlg()
|
|
{
|
|
sal_Bool bWeb = 0 != PTR_CAST(SwWebView, this);
|
|
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
|
|
SfxAbstractLinksDialog* pDlg = pFact->CreateLinksDialog( &GetViewFrame()->GetWindow(), &GetWrtShell().GetLinkManager(), bWeb );
|
|
if ( pDlg )
|
|
{
|
|
pDlg->Execute();
|
|
delete pDlg;
|
|
}
|
|
}
|
|
|
|
bool SwView::JumpToSwMark( const String& rMark )
|
|
{
|
|
bool bRet = false;
|
|
if( rMark.Len() )
|
|
{
|
|
// wir wollen den Bookmark aber am oberen Rand haben
|
|
sal_Bool bSaveCC = IsCrsrAtCenter();
|
|
sal_Bool bSaveCT = IsCrsrAtTop();
|
|
SetCrsrAtTop( sal_True );
|
|
|
|
// Damit in FrameSet auch gescrollt werden kann, muss die
|
|
// entsprechende Shell auch das Focus-Flag gesetzt haben!
|
|
sal_Bool bHasShFocus = m_pWrtShell->HasShFcs();
|
|
if( !bHasShFocus )
|
|
m_pWrtShell->ShGetFcs( sal_False );
|
|
|
|
const SwFmtINetFmt* pINet;
|
|
String sCmp, sMark( INetURLObject::decode( rMark, INET_HEX_ESCAPE,
|
|
INetURLObject::DECODE_WITH_CHARSET,
|
|
RTL_TEXTENCODING_UTF8 ));
|
|
|
|
xub_StrLen nLastPos, nPos = sMark.Search( cMarkSeparator );
|
|
if( STRING_NOTFOUND != nPos )
|
|
while( STRING_NOTFOUND != ( nLastPos =
|
|
sMark.Search( cMarkSeparator, nPos + 1 )) )
|
|
nPos = nLastPos;
|
|
|
|
IDocumentMarkAccess::const_iterator_t ppMark;
|
|
IDocumentMarkAccess* const pMarkAccess = m_pWrtShell->getIDocumentMarkAccess();
|
|
if( STRING_NOTFOUND != nPos )
|
|
sCmp = comphelper::string::remove(sMark.Copy(nPos + 1), ' ');
|
|
|
|
if( sCmp.Len() )
|
|
{
|
|
rtl::OUString sName( sMark.Copy( 0, nPos ) );
|
|
sCmp.ToLowerAscii();
|
|
FlyCntType eFlyType = FLYCNTTYPE_ALL;
|
|
|
|
if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToRegion ) )
|
|
{
|
|
m_pWrtShell->EnterStdMode();
|
|
bRet = m_pWrtShell->GotoRegion( sName );
|
|
}
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToOutline ) )
|
|
{
|
|
m_pWrtShell->EnterStdMode();
|
|
bRet = m_pWrtShell->GotoOutline( sName );
|
|
}
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToFrame ) )
|
|
eFlyType = FLYCNTTYPE_FRM;
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToGraphic ) )
|
|
eFlyType = FLYCNTTYPE_GRF;
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToOLE ) )
|
|
eFlyType = FLYCNTTYPE_OLE;
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToTable ) )
|
|
{
|
|
m_pWrtShell->EnterStdMode();
|
|
bRet = m_pWrtShell->GotoTable( sName );
|
|
}
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToSequence ) )
|
|
{
|
|
m_pWrtShell->EnterStdMode();
|
|
sal_Int32 nNoPos = sName.indexOf( cSequenceMarkSeparator );
|
|
if ( nNoPos != -1 )
|
|
{
|
|
sal_uInt16 nSeqNo = sName.copy( nNoPos + 1 ).toInt32();
|
|
sName = sName.copy( 0, nNoPos );
|
|
m_pWrtShell->GotoRefMark( sName, REF_SEQUENCEFLD, nSeqNo );
|
|
}
|
|
}
|
|
else if( COMPARE_EQUAL == sCmp.CompareToAscii( pMarkToText ) )
|
|
{
|
|
// Normale Textsuche
|
|
m_pWrtShell->EnterStdMode();
|
|
|
|
SearchOptions aSearchOpt(
|
|
SearchAlgorithms_ABSOLUTE, 0,
|
|
sName, OUString(),
|
|
SvtSysLocale().GetLanguageTag().getLocale(),
|
|
0,0,0,
|
|
TransliterationModules_IGNORE_CASE );
|
|
|
|
//todo/mba: assuming that notes shouldn't be searched
|
|
sal_Bool bSearchInNotes = sal_False;
|
|
if( m_pWrtShell->SearchPattern( aSearchOpt, bSearchInNotes, DOCPOS_START, DOCPOS_END ))
|
|
{
|
|
m_pWrtShell->EnterStdMode(); // Selektion wieder aufheben
|
|
bRet = true;
|
|
}
|
|
}
|
|
else if( pMarkAccess->getMarksEnd() != (ppMark = pMarkAccess->findMark(sMark)) )
|
|
m_pWrtShell->GotoMark( ppMark->get(), sal_False, sal_True ), bRet = true;
|
|
else if( 0 != ( pINet = m_pWrtShell->FindINetAttr( sMark ) )) {
|
|
m_pWrtShell->addCurrentPosition();
|
|
bRet = m_pWrtShell->GotoINetAttr( *pINet->GetTxtINetFmt() );
|
|
}
|
|
|
|
// fuer alle Arten von Flys
|
|
if( FLYCNTTYPE_ALL != eFlyType && m_pWrtShell->GotoFly( sName, eFlyType ))
|
|
{
|
|
bRet = true;
|
|
if( FLYCNTTYPE_FRM == eFlyType )
|
|
{
|
|
// TextFrames: Cursor in den Frame setzen
|
|
m_pWrtShell->UnSelectFrm();
|
|
m_pWrtShell->LeaveSelFrmMode();
|
|
}
|
|
else
|
|
{
|
|
m_pWrtShell->HideCrsr();
|
|
m_pWrtShell->EnterSelFrmMode();
|
|
}
|
|
}
|
|
}
|
|
else if( pMarkAccess->getMarksEnd() != (ppMark = pMarkAccess->findMark(sMark)))
|
|
m_pWrtShell->GotoMark( ppMark->get(), sal_False, sal_True ), bRet = true;
|
|
else if( 0 != ( pINet = m_pWrtShell->FindINetAttr( sMark ) ))
|
|
bRet = m_pWrtShell->GotoINetAttr( *pINet->GetTxtINetFmt() );
|
|
|
|
// make selection visible later
|
|
if ( m_aVisArea.IsEmpty() )
|
|
m_bMakeSelectionVisible = sal_True;
|
|
|
|
// ViewStatus wieder zurueck setzen
|
|
SetCrsrAtTop( bSaveCT, bSaveCC );
|
|
|
|
if( !bHasShFocus )
|
|
m_pWrtShell->ShLooseFcs();
|
|
}
|
|
return bRet;
|
|
}
|
|
|
|
// #i67305# Undo after insert from file:
|
|
// Undo "Insert form file" crashes with documents imported from binary filter (.sdw) => disabled
|
|
// Undo "Insert form file" crashes with (.odt) documents crashes if these documents contains
|
|
// page styles with active header/footer => disabled for those documents
|
|
static sal_uInt16 lcl_PageDescWithHeader( const SwDoc& rDoc )
|
|
{
|
|
sal_uInt16 nRet = 0;
|
|
sal_uInt16 nCnt = rDoc.GetPageDescCnt();
|
|
for( sal_uInt16 i = 0; i < nCnt; ++i )
|
|
{
|
|
const SwPageDesc& rPageDesc = rDoc.GetPageDesc( i );
|
|
const SwFrmFmt& rMaster = rPageDesc.GetMaster();
|
|
const SfxPoolItem* pItem;
|
|
if( ( SFX_ITEM_SET == rMaster.GetAttrSet().GetItemState( RES_HEADER, sal_False, &pItem ) &&
|
|
((SwFmtHeader*)pItem)->IsActive() ) ||
|
|
( SFX_ITEM_SET == rMaster.GetAttrSet().GetItemState( RES_FOOTER, sal_False, &pItem ) &&
|
|
((SwFmtFooter*)pItem)->IsActive()) )
|
|
++nRet;
|
|
}
|
|
return nRet; // number of page styles with active header/footer
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Links bearbeiten
|
|
--------------------------------------------------------------------*/
|
|
void SwView::ExecuteInsertDoc( SfxRequest& rRequest, const SfxPoolItem* pItem )
|
|
{
|
|
m_pViewImpl->InitRequest( rRequest );
|
|
m_pViewImpl->SetParam( pItem ? 1 : 0 );
|
|
sal_uInt16 nSlot = rRequest.GetSlot();
|
|
|
|
if ( !pItem )
|
|
{
|
|
String sEmpty;
|
|
InsertDoc( nSlot, sEmpty, sEmpty );
|
|
}
|
|
else
|
|
{
|
|
String sFile, sFilter;
|
|
sFile = ( (const SfxStringItem *)pItem )->GetValue();
|
|
if ( SFX_ITEM_SET == rRequest.GetArgs()->GetItemState( FN_PARAM_1, sal_True, &pItem ) )
|
|
sFilter = ( (const SfxStringItem *)pItem )->GetValue();
|
|
|
|
bool bHasFileName = ( sFile.Len() > 0 );
|
|
long nFound = InsertDoc( nSlot, sFile, sFilter );
|
|
|
|
if ( bHasFileName )
|
|
{
|
|
rRequest.SetReturnValue( SfxBoolItem( nSlot, nFound != -1 ) );
|
|
rRequest.Done();
|
|
}
|
|
}
|
|
}
|
|
|
|
long SwView::InsertDoc( sal_uInt16 nSlotId, const String& rFileName, const String& rFilterName, sal_Int16 nVersion )
|
|
{
|
|
SfxMedium* pMed = 0;
|
|
SwDocShell* pDocSh = GetDocShell();
|
|
|
|
if( rFileName.Len() )
|
|
{
|
|
SfxObjectFactory& rFact = pDocSh->GetFactory();
|
|
const SfxFilter* pFilter = rFact.GetFilterContainer()->GetFilter4FilterName( rFilterName );
|
|
if ( !pFilter )
|
|
{
|
|
pMed = new SfxMedium(rFileName, STREAM_READ, 0, 0 );
|
|
SfxFilterMatcher aMatcher( rFact.GetFilterContainer()->GetName() );
|
|
pMed->UseInteractionHandler( sal_True );
|
|
ErrCode nErr = aMatcher.GuessFilter( *pMed, &pFilter, sal_False );
|
|
if ( nErr )
|
|
DELETEZ(pMed);
|
|
else
|
|
pMed->SetFilter( pFilter );
|
|
}
|
|
else
|
|
pMed = new SfxMedium(rFileName, STREAM_READ, pFilter, 0);
|
|
}
|
|
else
|
|
{
|
|
OUString sFactory = OUString::createFromAscii( pDocSh->GetFactory().GetShortName() );
|
|
m_pViewImpl->StartDocumentInserter( sFactory, LINK( this, SwView, DialogClosedHdl ) );
|
|
return -1;
|
|
}
|
|
|
|
if( !pMed )
|
|
return -1;
|
|
|
|
return InsertMedium( nSlotId, pMed, nVersion );
|
|
}
|
|
|
|
long SwView::InsertMedium( sal_uInt16 nSlotId, SfxMedium* pMedium, sal_Int16 nVersion )
|
|
{
|
|
sal_Bool bInsert = sal_False, bCompare = sal_False;
|
|
long nFound = 0;
|
|
SwDocShell* pDocSh = GetDocShell();
|
|
|
|
switch( nSlotId )
|
|
{
|
|
case SID_DOCUMENT_MERGE: break;
|
|
case SID_DOCUMENT_COMPARE: bCompare = sal_True; break;
|
|
case SID_INSERTDOC: bInsert = sal_True; break;
|
|
|
|
default:
|
|
OSL_ENSURE( !this, "unknown SlotId!" );
|
|
bInsert = sal_True;
|
|
nSlotId = SID_INSERTDOC;
|
|
break;
|
|
}
|
|
|
|
if( bInsert )
|
|
{
|
|
uno::Reference< frame::XDispatchRecorder > xRecorder =
|
|
GetViewFrame()->GetBindings().GetRecorder();
|
|
if ( xRecorder.is() )
|
|
{
|
|
SfxRequest aRequest(GetViewFrame(), SID_INSERTDOC);
|
|
aRequest.AppendItem(SfxStringItem(SID_INSERTDOC, pMedium->GetOrigURL()));
|
|
if(pMedium->GetFilter())
|
|
aRequest.AppendItem(SfxStringItem(FN_PARAM_1, pMedium->GetFilter()->GetName()));
|
|
aRequest.Done();
|
|
}
|
|
|
|
SfxObjectShellRef aRef( pDocSh );
|
|
|
|
sal_uInt32 nError = SfxObjectShell::HandleFilter( pMedium, pDocSh );
|
|
// #i16722# aborted?
|
|
if(nError != ERRCODE_NONE)
|
|
{
|
|
delete pMedium;
|
|
return -1;
|
|
}
|
|
|
|
pMedium->DownLoad(); // ggfs. den DownLoad anstossen
|
|
if( aRef.Is() && 1 < aRef->GetRefCount() ) // noch gueltige Ref?
|
|
{
|
|
SwReader* pRdr;
|
|
Reader *pRead = pDocSh->StartConvertFrom( *pMedium, &pRdr, m_pWrtShell );
|
|
if( pRead ||
|
|
(pMedium->GetFilter()->GetFilterFlags() & SFX_FILTER_STARONEFILTER) != 0 )
|
|
{
|
|
sal_uInt16 nUndoCheck = 0;
|
|
SwDoc *pDoc = pDocSh->GetDoc();
|
|
if( pRead && pDocSh->GetDoc() )
|
|
nUndoCheck = lcl_PageDescWithHeader( *pDoc );
|
|
sal_uLong nErrno;
|
|
{ //Scope for SwWait-Object, to be able to execute slots
|
|
//outside this scope.
|
|
SwWait aWait( *GetDocShell(), sal_True );
|
|
m_pWrtShell->StartAllAction();
|
|
if ( m_pWrtShell->HasSelection() )
|
|
m_pWrtShell->DelRight(); // Selektionen loeschen
|
|
if( pRead )
|
|
{
|
|
nErrno = pRdr->Read( *pRead ); // und Dokument einfuegen
|
|
delete pRdr;
|
|
}
|
|
else
|
|
{
|
|
::sw::UndoGuard const ug(pDoc->GetIDocumentUndoRedo());
|
|
nErrno = pDocSh->ImportFrom( *pMedium, true ) ? 0 : ERR_SWG_READ_ERROR;
|
|
}
|
|
|
|
}
|
|
|
|
// ggfs. alle Verzeichnisse updaten:
|
|
if( m_pWrtShell->IsUpdateTOX() )
|
|
{
|
|
SfxRequest aReq( FN_UPDATE_TOX, SFX_CALLMODE_SLOT, GetPool() );
|
|
Execute( aReq );
|
|
m_pWrtShell->SetUpdateTOX( sal_False ); // wieder zurueck setzen
|
|
}
|
|
|
|
if( pDoc )
|
|
{ // Disable Undo for .sdw or
|
|
// if the number of page styles with header/footer has changed
|
|
if( !pRead || nUndoCheck != lcl_PageDescWithHeader( *pDoc ) )
|
|
{
|
|
pDoc->GetIDocumentUndoRedo().DelAllUndoObj();
|
|
}
|
|
}
|
|
|
|
m_pWrtShell->EndAllAction();
|
|
if( nErrno )
|
|
{
|
|
ErrorHandler::HandleError( nErrno );
|
|
nFound = IsError( nErrno ) ? -1 : 0;
|
|
}
|
|
else
|
|
nFound = 0;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
SfxObjectShellRef xDocSh;
|
|
SfxObjectShellLock xLockRef;
|
|
|
|
String sFltNm;
|
|
const int nRet = SwFindDocShell( xDocSh, xLockRef, pMedium->GetName(), OUString(),
|
|
sFltNm, nVersion, pDocSh );
|
|
if( nRet )
|
|
{
|
|
SwWait aWait( *GetDocShell(), sal_True );
|
|
m_pWrtShell->StartAllAction();
|
|
|
|
m_pWrtShell->EnterStdMode(); // Selektionen loeschen
|
|
|
|
if( bCompare )
|
|
nFound = m_pWrtShell->CompareDoc( *((SwDocShell*)&xDocSh)->GetDoc() );
|
|
else
|
|
nFound = m_pWrtShell->MergeDoc( *((SwDocShell*)&xDocSh)->GetDoc() );
|
|
|
|
m_pWrtShell->EndAllAction();
|
|
|
|
if (!bCompare && !nFound)
|
|
{
|
|
Window* pWin = &GetEditWin();
|
|
InfoBox(pWin, SW_RES(MSG_NO_MERGE_ENTRY)).Execute();
|
|
}
|
|
if( nRet==2 && xDocSh.Is() )
|
|
xDocSh->DoClose();
|
|
}
|
|
}
|
|
|
|
delete pMedium;
|
|
return nFound;
|
|
}
|
|
|
|
void SwView::EnableMailMerge(sal_Bool bEnable )
|
|
{
|
|
m_bInMailMerge = bEnable;
|
|
SfxBindings& rBind = GetViewFrame()->GetBindings();
|
|
rBind.Invalidate(FN_INSERT_FIELD_DATA_ONLY);
|
|
rBind.Update(FN_INSERT_FIELD_DATA_ONLY);
|
|
}
|
|
|
|
namespace
|
|
{
|
|
sal_Bool lcl_NeedAdditionalDataSource( const uno::Reference< XDatabaseContext >& _rDatasourceContext )
|
|
{
|
|
Sequence < OUString > aNames = _rDatasourceContext->getElementNames();
|
|
|
|
return ( !aNames.getLength()
|
|
|| ( ( 1 == aNames.getLength() )
|
|
&& aNames.getConstArray()[0] == SW_MOD()->GetDBConfig()->GetBibliographySource().sDataSource
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
class SwMergeSourceWarningBox_Impl : public ModalDialog
|
|
{
|
|
FixedInfo aMessageFI;
|
|
OKButton aOK;
|
|
CancelButton aCancel;
|
|
|
|
FixedImage aWarnImage;
|
|
public:
|
|
SwMergeSourceWarningBox_Impl( Window* pParent ) :
|
|
ModalDialog( pParent, SW_RES( DLG_MERGE_SOURCE_UNAVAILABLE ) ),
|
|
aMessageFI( this, SW_RES( ST_MERGE_SOURCE_UNAVAILABLE ) ),
|
|
aOK( this, SW_RES( PB_MERGE_OK ) ),
|
|
aCancel( this, SW_RES( PB_MERGE_CANCEL ) ),
|
|
aWarnImage( this, SW_RES( IMG_MERGE ) )
|
|
{
|
|
FreeResource();
|
|
SetText( Application::GetDisplayName() );
|
|
const Image& rImg = WarningBox::GetStandardImage();
|
|
aWarnImage.SetImage( rImg );
|
|
Size aImageSize( rImg.GetSizePixel() );
|
|
aImageSize.Width() += 4;
|
|
aImageSize.Height() += 4;
|
|
aWarnImage.SetSizePixel( aImageSize );
|
|
|
|
aImageSize.Width() += aWarnImage.GetPosPixel().X();
|
|
Size aSz(GetSizePixel());
|
|
aSz.Width() += aImageSize.Width();
|
|
SetSizePixel(aSz);
|
|
|
|
Point aPos(aMessageFI.GetPosPixel());
|
|
aPos.X() += aImageSize.Width();
|
|
aMessageFI.SetPosPixel( aPos );
|
|
|
|
aPos = aOK.GetPosPixel();
|
|
aPos.X() += aImageSize.Width();
|
|
aOK.SetPosPixel( aPos );
|
|
aPos = aCancel.GetPosPixel();
|
|
aPos.X() += aImageSize.Width();
|
|
aCancel.SetPosPixel( aPos );
|
|
|
|
}
|
|
|
|
String GetMessText() const { return aMessageFI.GetText(); }
|
|
void SetMessText( const String& rText ) { aMessageFI.SetText( rText ); }
|
|
};
|
|
|
|
void SwView::GenerateFormLetter(sal_Bool bUseCurrentDocument)
|
|
{
|
|
if(bUseCurrentDocument)
|
|
{
|
|
if(!GetWrtShell().IsAnyDatabaseFieldInDoc())
|
|
{
|
|
//check availability of data sources (except biblio source)
|
|
uno::Reference<XComponentContext> xContext( ::comphelper::getProcessComponentContext() );
|
|
uno::Reference<XDatabaseContext> xDBContext = DatabaseContext::create(xContext);
|
|
sal_Bool bCallAddressPilot = sal_False;
|
|
if ( lcl_NeedAdditionalDataSource( xDBContext ) )
|
|
{
|
|
// no data sources are available - create a new one
|
|
MessageDialog aQuery(&GetViewFrame()->GetWindow(),
|
|
"DataSourcesUnavailableDialog",
|
|
"modules/swriter/ui/datasourcesunavailabledialog.ui");
|
|
// no cancel allowed
|
|
if (RET_OK != aQuery.Execute())
|
|
return;
|
|
bCallAddressPilot = sal_True;
|
|
}
|
|
else
|
|
{
|
|
//take an existing data source or create a new one?
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
|
|
OSL_ENSURE(pFact, "Dialogdiet fail!");
|
|
AbstractMailMergeFieldConnectionsDlg* pConnectionsDlg = pFact->CreateMailMergeFieldConnectionsDlg(
|
|
DLG_MERGE_FIELD_CONNECTIONS,
|
|
&GetViewFrame()->GetWindow());
|
|
OSL_ENSURE(pConnectionsDlg, "Dialogdiet fail!");
|
|
if(RET_OK == pConnectionsDlg->Execute())
|
|
bCallAddressPilot = !pConnectionsDlg->IsUseExistingConnections();
|
|
else
|
|
return;
|
|
|
|
}
|
|
if(bCallAddressPilot)
|
|
{
|
|
GetViewFrame()->GetDispatcher()->Execute(
|
|
SID_ADDRESS_DATA_SOURCE, SFX_CALLMODE_SYNCHRON);
|
|
if ( lcl_NeedAdditionalDataSource( xDBContext ) )
|
|
// no additional data source has been created
|
|
// -> assume that the user has cancelled the pilot
|
|
return;
|
|
}
|
|
|
|
//call insert fields with database field page available, only
|
|
SfxViewFrame* pVFrame = GetViewFrame();
|
|
//at first hide the default field dialog if currently visible
|
|
pVFrame->SetChildWindow(FN_INSERT_FIELD, sal_False);
|
|
//enable the status of the db field dialog - it is disabled in the status method
|
|
//to prevent creation of the dialog without mail merge active
|
|
EnableMailMerge();
|
|
//then show the "Data base only" field dialog
|
|
SfxBoolItem aOn(FN_INSERT_FIELD_DATA_ONLY, sal_True);
|
|
pVFrame->GetDispatcher()->Execute(FN_INSERT_FIELD_DATA_ONLY,
|
|
SFX_CALLMODE_SYNCHRON, &aOn, 0L);
|
|
return;
|
|
}
|
|
else
|
|
{
|
|
// check whether the
|
|
String sSource;
|
|
if(!GetWrtShell().IsFieldDataSourceAvailable(sSource))
|
|
{
|
|
SwMergeSourceWarningBox_Impl aWarning( &GetViewFrame()->GetWindow());
|
|
String sTmp(aWarning.GetMessText());
|
|
sTmp.SearchAndReplaceAscii("%1", sSource);
|
|
aWarning.SetMessText(sTmp);
|
|
if(RET_OK == aWarning.Execute())
|
|
{
|
|
SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
|
|
if ( pFact )
|
|
{
|
|
VclAbstractDialog* pDlg = pFact->CreateVclDialog( NULL, SID_OPTIONS_DATABASES );
|
|
pDlg->Execute();
|
|
delete pDlg;
|
|
}
|
|
}
|
|
return ;
|
|
}
|
|
}
|
|
SwNewDBMgr* pNewDBMgr = GetWrtShell().GetNewDBMgr();
|
|
|
|
SwDBData aData;
|
|
SwWrtShell &rSh = GetWrtShell();
|
|
|
|
std::vector<String> aDBNameList;
|
|
std::vector<String> aAllDBNames;
|
|
rSh.GetAllUsedDB( aDBNameList, &aAllDBNames );
|
|
if(!aDBNameList.empty())
|
|
{
|
|
String sDBName(aDBNameList[0]);
|
|
aData.sDataSource = sDBName.GetToken(0, DB_DELIM);
|
|
aData.sCommand = sDBName.GetToken(1, DB_DELIM);
|
|
aData.nCommandType = sDBName.GetToken(2, DB_DELIM ).ToInt32();
|
|
}
|
|
rSh.EnterStdMode(); // Wechsel in Textshell erzwingen; ist fuer
|
|
// das Mischen von DB-Feldern notwendig.
|
|
AttrChangedNotify( &rSh );
|
|
|
|
if (pNewDBMgr)
|
|
{
|
|
pNewDBMgr->SetMergeType( DBMGR_MERGE );
|
|
|
|
Sequence<PropertyValue> aProperties(3);
|
|
PropertyValue* pValues = aProperties.getArray();
|
|
pValues[0].Name = "DataSourceName";
|
|
pValues[1].Name = "Command";
|
|
pValues[2].Name = "CommandType";
|
|
pValues[0].Value <<= aData.sDataSource;
|
|
pValues[1].Value <<= aData.sCommand;
|
|
pValues[2].Value <<= aData.nCommandType;
|
|
pNewDBMgr->ExecuteFormLetter(GetWrtShell(), aProperties, sal_True);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//call documents and template dialog
|
|
SfxApplication* pSfxApp = SFX_APP();
|
|
Window* pTopWin = pSfxApp->GetTopWindow();
|
|
SvtDocumentTemplateDialog* pDocTemplDlg = new SvtDocumentTemplateDialog( pTopWin );
|
|
pDocTemplDlg->SelectTemplateFolder();
|
|
|
|
int nRet = pDocTemplDlg->Execute();
|
|
sal_Bool bNewWin = sal_False;
|
|
if ( nRet == RET_OK )
|
|
{
|
|
if ( pTopWin != pSfxApp->GetTopWindow() )
|
|
{
|
|
// the dialogue opens a document -> a new TopWindow appears
|
|
pTopWin = pSfxApp->GetTopWindow();
|
|
bNewWin = sal_True;
|
|
}
|
|
}
|
|
|
|
delete pDocTemplDlg;
|
|
if ( bNewWin )
|
|
// after the destruction of the dialogue its parent comes to top,
|
|
// but we want that the new document is on top
|
|
pTopWin->ToTop();
|
|
}
|
|
}
|
|
|
|
IMPL_LINK( SwView, DialogClosedHdl, sfx2::FileDialogHelper*, _pFileDlg )
|
|
{
|
|
if ( ERRCODE_NONE == _pFileDlg->GetError() )
|
|
{
|
|
SfxMedium* pMed = m_pViewImpl->CreateMedium();
|
|
if ( pMed )
|
|
{
|
|
sal_uInt16 nSlot = m_pViewImpl->GetRequest()->GetSlot();
|
|
long nFound = InsertMedium( nSlot, pMed, m_pViewImpl->GetParam() );
|
|
|
|
if ( SID_INSERTDOC == nSlot )
|
|
{
|
|
if ( m_pViewImpl->GetParam() == 0 )
|
|
{
|
|
m_pViewImpl->GetRequest()->SetReturnValue( SfxBoolItem( nSlot, nFound != -1 ) );
|
|
m_pViewImpl->GetRequest()->Ignore();
|
|
}
|
|
else
|
|
{
|
|
m_pViewImpl->GetRequest()->SetReturnValue( SfxBoolItem( nSlot, nFound != -1 ) );
|
|
m_pViewImpl->GetRequest()->Done();
|
|
}
|
|
}
|
|
else if ( SID_DOCUMENT_COMPARE == nSlot || SID_DOCUMENT_MERGE == nSlot )
|
|
{
|
|
m_pViewImpl->GetRequest()->SetReturnValue( SfxInt32Item( nSlot, nFound ) );
|
|
|
|
if ( nFound > 0 ) // Redline-Browser anzeigen
|
|
{
|
|
SfxViewFrame* pVFrame = GetViewFrame();
|
|
pVFrame->ShowChildWindow(FN_REDLINE_ACCEPT);
|
|
|
|
// RedlineDlg neu initialisieren
|
|
sal_uInt16 nId = SwRedlineAcceptChild::GetChildWindowId();
|
|
SwRedlineAcceptChild* pRed = (SwRedlineAcceptChild*)pVFrame->GetChildWindow( nId );
|
|
if ( pRed )
|
|
pRed->ReInitDlg( GetDocShell() );
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
void SwView::ExecuteScan( SfxRequest& rReq )
|
|
{
|
|
if (m_pViewImpl)
|
|
m_pViewImpl->ExecuteScan(rReq) ;
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|