/* -*- 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 #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include // TECHNICALLY not possible !! #include #include #include #include #include #include #include #include #include // needed for -fsanitize=function visibility of typeinfo for functions of // type void(SfxShell*,SfxRequest&) defined in swslots.hxx #define SwWebView #define Text #define TextInTable #define ListInText #define ListInTable #include SFX_IMPL_NAMED_VIEWFACTORY(SwWebView, "Default") { SFX_VIEW_REGISTRATION(SwWebDocShell); } SFX_IMPL_INTERFACE(SwWebView, SwView) void SwWebView::InitInterface_Impl() { GetStaticInterface()->RegisterChildWindow(SvxSearchDialogWrapper::GetChildWindowId()); GetStaticInterface()->RegisterChildWindow(SfxInfoBarContainerChild::GetChildWindowId()); GetStaticInterface()->RegisterObjectBar(SFX_OBJECTBAR_TOOLS|SFX_VISIBILITY_STANDARD|SFX_VISIBILITY_SERVER, RID_WEBTOOLS_TOOLBOX); } TYPEINIT1(SwWebView,SwView) SwWebView::SwWebView(SfxViewFrame* _pFrame, SfxViewShell* _pShell) : SwView(_pFrame, _pShell) { } SwWebView::~SwWebView() { } void SwWebView::SelectShell() { #if HAVE_FEATURE_DESKTOP // 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( 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; } if (i) { 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( false ); //now the table update if(bUpdateTable) GetWrtShell().UpdateTable(); #endif } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */