diff options
Diffstat (limited to 'sw/source/core/uibase/web/wview.cxx')
-rw-r--r-- | sw/source/core/uibase/web/wview.cxx | 288 |
1 files changed, 288 insertions, 0 deletions
diff --git a/sw/source/core/uibase/web/wview.cxx b/sw/source/core/uibase/web/wview.cxx new file mode 100644 index 000000000000..5e733721c280 --- /dev/null +++ b/sw/source/core/uibase/web/wview.cxx @@ -0,0 +1,288 @@ +/* -*- 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 <sfx2/msg.hxx> +#include <svl/srchitem.hxx> +#include <sfx2/dispatch.hxx> +#include <sfx2/infobar.hxx> +#include <sfx2/templdlg.hxx> +#include <svx/srchdlg.hxx> +#include <basic/sbxobj.hxx> +#include <uivwimp.hxx> +#include <svx/fmshell.hxx> +#include <svx/extrusionbar.hxx> +#include <svx/fontworkbar.hxx> + +#include <sfx2/objface.hxx> +#include <swmodule.hxx> +#include <unotxvw.hxx> +#include <swtypes.hxx> +#include <cmdid.h> +#include <globals.hrc> +#include <wrtsh.hxx> +#include <edtwin.hxx> +#include <wgrfsh.hxx> +#include <wfrmsh.hxx> +#include <wolesh.hxx> +#include <wtabsh.hxx> +#include <wlistsh.hxx> +#include <wformsh.hxx> +#include <wtextsh.hxx> +#include <barcfg.hxx> +#include <doc.hxx> + +// TECHNICALLY not possible !! +#include <beziersh.hxx> +#include <drawsh.hxx> +#include <drwtxtsh.hxx> +#include <annotsh.hxx> + +#include <wview.hxx> +#include <wdocsh.hxx> +#include <web.hrc> +#include <shells.hrc> + +#define SwWebView +#define Text +#define TextInTable +#define ListInText +#define ListInTable +#include <swslots.hxx> + +SFX_IMPL_NAMED_VIEWFACTORY(SwWebView, "Default") +{ + SFX_VIEW_REGISTRATION(SwWebDocShell); +} + +SFX_IMPL_INTERFACE( SwWebView, SwView, SW_RES(RID_WEBTOOLS_TOOLBOX) ) +{ + SFX_CHILDWINDOW_REGISTRATION(SfxTemplateDialogWrapper::GetChildWindowId()); + SFX_CHILDWINDOW_REGISTRATION(SvxSearchDialogWrapper::GetChildWindowId()); + SFX_CHILDWINDOW_REGISTRATION(SfxInfoBarContainerChild::GetChildWindowId()); + SFX_OBJECTBAR_REGISTRATION( SFX_OBJECTBAR_TOOLS| + SFX_VISIBILITY_STANDARD|SFX_VISIBILITY_SERVER, + SW_RES(RID_WEBTOOLS_TOOLBOX) ); +} + +TYPEINIT1(SwWebView,SwView) + +SwWebView::SwWebView(SfxViewFrame* _pFrame, SfxViewShell* _pShell) : + SwView(_pFrame, _pShell) +{ +} + +SwWebView::~SwWebView() +{ +} + +void SwWebView::SelectShell() +{ + // Decision whether UpdateTable must be called + bool bUpdateTable = false; + const SwFrmFmt* pCurTableFmt = GetWrtShell().GetTableFmt(); + if(pCurTableFmt && pCurTableFmt != GetLastTblFrmFmt()) + { + bUpdateTable = true; // can only be executed later + } + SetLastTblFrmFmt(pCurTableFmt); + //SEL_TBL and SEL_TBL_CELLS can be ored! + int nNewSelectionType = (GetWrtShell().GetSelectionType() + & ~nsSelectionType::SEL_TBL_CELLS); + + int _nSelectionType = GetSelectionType(); + if ( nNewSelectionType == _nSelectionType ) + { + GetViewFrame()->GetBindings().InvalidateAll( sal_False ); + if ( _nSelectionType & nsSelectionType::SEL_OLE || + _nSelectionType & nsSelectionType::SEL_GRF ) + //The verb may of course change for graphics and OLE! + ImpSetVerb( nNewSelectionType ); + } + else + { + SfxDispatcher &rDispatcher = *GetViewFrame()->GetDispatcher(); + SwToolbarConfigItem *pBarCfg = SW_MOD()->GetWebToolbarConfig(); + + if( GetCurShell() ) + { + rDispatcher.Flush(); // really delete all cached shells + + //Additional to the old selection remember which toolbar was visible. + sal_Int32 nId = rDispatcher.GetObjectBarId( SFX_OBJECTBAR_OBJECT ); + if ( nId ) + pBarCfg->SetTopToolbar( _nSelectionType, nId ); + + SfxShell *pSfxShell; + sal_uInt16 i; + for ( i = 0; true; ++i ) + { + pSfxShell = rDispatcher.GetShell( i ); + if ( !( pSfxShell->ISA( SwBaseShell ) || + pSfxShell->ISA( SwDrawTextShell ) || pSfxShell->ISA( SwAnnotationShell ) ) ) + break; + } + pSfxShell = rDispatcher.GetShell( --i ); + OSL_ENSURE( pSfxShell, "My Shell ist lost in space" ); + rDispatcher.Pop( *pSfxShell, SFX_SHELL_POP_UNTIL | SFX_SHELL_POP_DELETE); + } + + bool bInitFormShell = false; + if( !GetFormShell() ) + { + bInitFormShell = true; + SetFormShell( new FmFormShell( this ) ); + rDispatcher.Push( *GetFormShell() ); + } + + bool bSetExtInpCntxt = false; + _nSelectionType = nNewSelectionType; + SetSelectionType( _nSelectionType ); + ShellModes eShellMode; + + if ( _nSelectionType & nsSelectionType::SEL_OLE ) + { + eShellMode = SHELL_MODE_OBJECT; + SetShell( new SwWebOleShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + else if ( _nSelectionType & nsSelectionType::SEL_FRM + || _nSelectionType & nsSelectionType::SEL_GRF) + { + eShellMode = SHELL_MODE_FRAME; + SetShell( new SwWebFrameShell( *this )); + rDispatcher.Push( *GetCurShell() ); + if(_nSelectionType & nsSelectionType::SEL_GRF ) + { + eShellMode = SHELL_MODE_GRAPHIC; + SetShell( new SwWebGrfShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + } + else if ( _nSelectionType & nsSelectionType::SEL_FRM ) + { + eShellMode = SHELL_MODE_FRAME; + SetShell( new SwWebFrameShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + else if ( _nSelectionType & nsSelectionType::SEL_DRW ) + { + eShellMode = SHELL_MODE_DRAW; + SetShell( new svx::ExtrusionBar( this ) ); + rDispatcher.Push( *GetCurShell() ); + + SetShell( new svx::FontworkBar( this ) ); + rDispatcher.Push( *GetCurShell() ); + + SetShell( new SwDrawShell( *this )); + rDispatcher.Push( *GetCurShell() ); + if ( _nSelectionType & nsSelectionType::SEL_BEZ ) + { + eShellMode = SHELL_MODE_BEZIER; + SetShell( new SwBezierShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + + } + else if ( _nSelectionType & nsSelectionType::SEL_DRW_FORM ) + { + eShellMode = SHELL_MODE_DRAW_FORM; + SetShell( new SwWebDrawFormShell( *this )); + + rDispatcher.Push( *GetCurShell() ); + } + else if ( _nSelectionType & nsSelectionType::SEL_DRW_TXT ) + { + eShellMode = SHELL_MODE_DRAWTEXT; + rDispatcher.Push( *(new SwBaseShell( *this )) ); + SetShell( new SwDrawTextShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + else if ( _nSelectionType & nsSelectionType::SEL_POSTIT ) + { + eShellMode = SHELL_MODE_POSTIT; + SetShell( new SwAnnotationShell( *this ) ); + rDispatcher.Push( *GetCurShell() ); + } + else + { + bSetExtInpCntxt = true; + eShellMode = SHELL_MODE_TEXT; + if ( _nSelectionType & nsSelectionType::SEL_NUM ) + { + eShellMode = SHELL_MODE_LIST_TEXT; + SetShell( new SwWebListShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + SetShell( new SwWebTextShell(*this)); + rDispatcher.Push( *GetCurShell() ); + if ( _nSelectionType & nsSelectionType::SEL_TBL ) + { + eShellMode = eShellMode == SHELL_MODE_LIST_TEXT ? SHELL_MODE_TABLE_LIST_TEXT + : SHELL_MODE_TABLE_TEXT; + SetShell( new SwWebTableShell( *this )); + rDispatcher.Push( *GetCurShell() ); + } + } + ImpSetVerb( _nSelectionType ); + GetViewImpl()->SetShellMode(eShellMode); + + if( !GetDocShell()->IsReadOnly() ) + { + if( bSetExtInpCntxt && GetWrtShell().HasReadonlySel() ) + bSetExtInpCntxt = false; + + InputContext aCntxt( GetEditWin().GetInputContext() ); + aCntxt.SetOptions( bSetExtInpCntxt + ? (aCntxt.GetOptions() | + ( INPUTCONTEXT_TEXT | + INPUTCONTEXT_EXTTEXTINPUT )) + : (aCntxt.GetOptions() & ~ + ( INPUTCONTEXT_TEXT | + INPUTCONTEXT_EXTTEXTINPUT )) ); + GetEditWin().SetInputContext( aCntxt ); + } + + //Additional to the selection enable the toolbar, which was + //activated last time + //Before must be a Flush(), but concerns according to MBA not the + //user interface and is not a performance issue. + // TODO/LATER: maybe now the Flush() command is superfluous?! + rDispatcher.Flush(); + + Point aPnt = GetEditWin().GetPointerPosPixel(); + aPnt = GetEditWin().PixelToLogic(aPnt); + GetEditWin().UpdatePointer(aPnt); + + if ( bInitFormShell && GetWrtShell().GetDrawView() ) + GetFormShell()->SetView( PTR_CAST( FmFormView, + GetWrtShell().GetDrawView())); + + } + GetViewImpl()->GetUNOObject_Impl()->NotifySelChanged(); + + //Opportune time for the communication with OLE objects? + if ( GetDocShell()->GetDoc()->IsOLEPrtNotifyPending() ) + GetDocShell()->GetDoc()->PrtOLENotify( sal_False ); + + //now the table update + if(bUpdateTable) + GetWrtShell().UpdateTable(); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |