summaryrefslogtreecommitdiff
path: root/sw/source
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2020-12-04 16:30:31 +0000
committerCaolán McNamara <caolanm@redhat.com>2021-02-06 12:16:04 +0100
commit69c546e1e7a697217f273baa7c1729ff823efd76 (patch)
tree4533c38b84d1cd57f86094ac816f0eb7c526ade1 /sw/source
parent2c61782812b1b8b382dd48a04a712da9eaeb4685 (diff)
weld annotation window
note the labels in sw/uiconfig/swriter/ui/annotation.ui are deliberately yaligned to 0 to retain the preexisting SwAnnotationWin::PaintTile hack which depends on this for bin/run gtktiledviewer --enable-tiled-annotations to not show clipped author/date/etc labels Change-Id: I53827aa98ed4d71d532a5993d21c6e22190b8063 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/107264 Tested-by: Jenkins Reviewed-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'sw/source')
-rw-r--r--sw/source/uibase/docvw/AnnotationMenuButton.cxx213
-rw-r--r--sw/source/uibase/docvw/AnnotationMenuButton.hxx51
-rw-r--r--sw/source/uibase/docvw/AnnotationWin.cxx83
-rw-r--r--sw/source/uibase/docvw/AnnotationWin2.cxx696
-rw-r--r--sw/source/uibase/docvw/PostItMgr.cxx5
-rw-r--r--sw/source/uibase/docvw/SidebarScrollBar.cxx73
-rw-r--r--sw/source/uibase/docvw/SidebarScrollBar.hxx40
-rw-r--r--sw/source/uibase/docvw/SidebarTxtControl.cxx328
-rw-r--r--sw/source/uibase/docvw/SidebarTxtControl.hxx49
-rw-r--r--sw/source/uibase/docvw/SidebarTxtControlAcc.cxx271
-rw-r--r--sw/source/uibase/docvw/SidebarTxtControlAcc.hxx43
11 files changed, 461 insertions, 1391 deletions
diff --git a/sw/source/uibase/docvw/AnnotationMenuButton.cxx b/sw/source/uibase/docvw/AnnotationMenuButton.cxx
index a38cba50aa04..48f848416ec6 100644
--- a/sw/source/uibase/docvw/AnnotationMenuButton.cxx
+++ b/sw/source/uibase/docvw/AnnotationMenuButton.cxx
@@ -17,117 +17,86 @@
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
-#include "AnnotationMenuButton.hxx"
-
+#include <AnnotationWin.hxx>
#include <strings.hrc>
#include <unotools/useroptions.hxx>
-#include <vcl/menu.hxx>
-#include <vcl/decoview.hxx>
-#include <vcl/gradient.hxx>
-#include <vcl/settings.hxx>
#include <vcl/event.hxx>
#include <cmdid.h>
-#include <AnnotationWin.hxx>
+
#include <swtypes.hxx>
namespace sw::annotation {
-static Color ColorFromAlphaColor(const sal_uInt8 aTransparency, const Color& aFront, const Color& aBack)
-{
- return Color(sal_uInt8(aFront.GetRed() * aTransparency / 255.0 + aBack.GetRed() * (1 - aTransparency / 255.0)),
- sal_uInt8(aFront.GetGreen() * aTransparency / 255.0 + aBack.GetGreen() * (1 - aTransparency / 255.0)),
- sal_uInt8(aFront.GetBlue() * aTransparency / 255.0 + aBack.GetBlue() * (1 - aTransparency / 255.0)));
-}
-
-AnnotationMenuButton::AnnotationMenuButton(sw::annotation::SwAnnotationWin& rSidebarWin)
- : MenuButton(&rSidebarWin)
- , mrSidebarWin(rSidebarWin)
-{
- AddEventListener(LINK(&mrSidebarWin, sw::annotation::SwAnnotationWin, WindowEventListener));
-
- SetAccessibleName(SwResId(STR_ACCESS_ANNOTATION_BUTTON_NAME));
- SetAccessibleDescription(SwResId(STR_ACCESS_ANNOTATION_BUTTON_DESC));
- SetQuickHelpText(GetAccessibleDescription());
-}
-
-AnnotationMenuButton::~AnnotationMenuButton()
-{
- disposeOnce();
-}
-
-void AnnotationMenuButton::dispose()
-{
- RemoveEventListener(LINK(&mrSidebarWin, sw::annotation::SwAnnotationWin, WindowEventListener));
- MenuButton::dispose();
-}
-
-void AnnotationMenuButton::Select()
+IMPL_LINK(SwAnnotationWin, SelectHdl, const OString&, rIdent, void)
{
- OString sIdent = GetCurItemIdent();
- if (sIdent.isEmpty())
+ if (rIdent.isEmpty())
return;
// tdf#136682 ensure this is the currently active sidebar win so the command
// operates in an active sidebar context
- bool bSwitchedFocus = mrSidebarWin.SetActiveSidebarWin();
-
- if (sIdent == "reply")
- mrSidebarWin.ExecuteCommand(FN_REPLY);
- if (sIdent == "resolve" || sIdent == "unresolve")
- mrSidebarWin.ExecuteCommand(FN_RESOLVE_NOTE);
- else if (sIdent == "resolvethread" || sIdent == "unresolvethread")
- mrSidebarWin.ExecuteCommand(FN_RESOLVE_NOTE_THREAD);
- else if (sIdent == "delete")
- mrSidebarWin.ExecuteCommand(FN_DELETE_COMMENT);
- else if (sIdent == "deletethread")
- mrSidebarWin.ExecuteCommand(FN_DELETE_COMMENT_THREAD);
- else if (sIdent == "deleteby")
- mrSidebarWin.ExecuteCommand(FN_DELETE_NOTE_AUTHOR);
- else if (sIdent == "deleteall")
- mrSidebarWin.ExecuteCommand(FN_DELETE_ALL_NOTES);
- else if (sIdent == "formatall")
- mrSidebarWin.ExecuteCommand(FN_FORMAT_ALL_NOTES);
+ bool bSwitchedFocus = SetActiveSidebarWin();
+
+ if (rIdent == "reply")
+ ExecuteCommand(FN_REPLY);
+ if (rIdent == "resolve" || rIdent == "unresolve")
+ ExecuteCommand(FN_RESOLVE_NOTE);
+ else if (rIdent == "resolvethread" || rIdent == "unresolvethread")
+ ExecuteCommand(FN_RESOLVE_NOTE_THREAD);
+ else if (rIdent == "delete")
+ ExecuteCommand(FN_DELETE_COMMENT);
+ else if (rIdent == "deletethread")
+ ExecuteCommand(FN_DELETE_COMMENT_THREAD);
+ else if (rIdent == "deleteby")
+ ExecuteCommand(FN_DELETE_NOTE_AUTHOR);
+ else if (rIdent == "deleteall")
+ ExecuteCommand(FN_DELETE_ALL_NOTES);
+ else if (rIdent == "formatall")
+ ExecuteCommand(FN_FORMAT_ALL_NOTES);
if (bSwitchedFocus)
- mrSidebarWin.UnsetActiveSidebarWin();
- mrSidebarWin.GrabFocusToDocument();
+ UnsetActiveSidebarWin();
+ GrabFocusToDocument();
}
-void AnnotationMenuButton::MouseButtonDown( const MouseEvent& rMEvt )
+IMPL_LINK_NOARG(SwAnnotationWin, ToggleHdl, weld::ToggleButton&, void)
{
- PopupMenu* pButtonPopup(GetPopupMenu());
- if (mrSidebarWin.IsReadOnly())
+ if (!mxMenuButton->get_active())
+ return;
+
+ bool bReplyVis = true;
+
+ bool bReadOnly = IsReadOnly();
+ if (bReadOnly)
{
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("reply"), false);
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("resolve"), false);
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("unresolve"), false);
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("resolvethread"), false);
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("unresolvethread"), false);
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("delete"), false );
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("deletethread"), false );
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("deleteby"), false );
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("deleteall"), false );
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("formatall"), false );
+ mxMenuButton->set_item_visible("reply", false);
+ bReplyVis = false;
+ mxMenuButton->set_item_visible("resolve", false);
+ mxMenuButton->set_item_visible("unresolve", false);
+ mxMenuButton->set_item_visible("resolvethread", false);
+ mxMenuButton->set_item_visible("unresolvethread", false);
+ mxMenuButton->set_item_visible("delete", false );
}
else
{
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("resolve"), !mrSidebarWin.IsResolved());
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("unresolve"), mrSidebarWin.IsResolved());
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("resolvethread"), !mrSidebarWin.IsThreadResolved());
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("unresolvethread"), mrSidebarWin.IsThreadResolved());
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("delete"), !mrSidebarWin.IsProtected());
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("deletethread"));
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("deleteby"));
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("deleteall"));
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("formatall"));
+ mxMenuButton->set_item_visible("resolve", !IsResolved());
+ mxMenuButton->set_item_visible("unresolve", IsResolved());
+ mxMenuButton->set_item_visible("resolvethread", !IsThreadResolved());
+ mxMenuButton->set_item_visible("unresolvethread", IsThreadResolved());
+ mxMenuButton->set_item_visible("delete", !IsProtected());
}
- if (mrSidebarWin.IsProtected())
+ mxMenuButton->set_item_visible("deletethread", !bReadOnly);
+ mxMenuButton->set_item_visible("deleteby", !bReadOnly);
+ mxMenuButton->set_item_visible("deleteall", !bReadOnly);
+ mxMenuButton->set_item_visible("formatall", !bReadOnly);
+
+ if (IsProtected())
{
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("reply"), false);
+ mxMenuButton->set_item_visible("reply", false);
+ bReplyVis = false;
}
else
{
@@ -141,84 +110,22 @@ void AnnotationMenuButton::MouseButtonDown( const MouseEvent& rMEvt )
}
}
// do not allow to reply to ourself and no answer possible if this note is in a protected section
- if (sAuthor == mrSidebarWin.GetAuthor())
- {
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("reply"), false);
- }
- else
- {
- pButtonPopup->EnableItem(pButtonPopup->GetItemId("reply"));
- }
- }
-
- MenuButton::MouseButtonDown(rMEvt);
-}
-
-void AnnotationMenuButton::Paint(vcl::RenderContext& rRenderContext, const tools::Rectangle& /*rRect*/)
-{
- bool bHighContrast = rRenderContext.GetSettings().GetStyleSettings().GetHighContrastMode();
-
- if (bHighContrast)
- rRenderContext.SetFillColor(COL_BLACK);
- else
- rRenderContext.SetFillColor(mrSidebarWin.ColorDark());
- rRenderContext.SetLineColor();
- const tools::Rectangle aRect(tools::Rectangle(Point(0, 0), rRenderContext.PixelToLogic(GetSizePixel())));
- rRenderContext.DrawRect(aRect);
-
- if (bHighContrast)
- {
- //draw rect around button
- rRenderContext.SetFillColor(COL_BLACK);
- rRenderContext.SetLineColor(COL_WHITE);
- }
- else
- {
- //draw button
- Gradient aGradient;
- if (IsMouseOver())
- aGradient = Gradient(GradientStyle::Linear,
- ColorFromAlphaColor(80, mrSidebarWin.ColorAnchor(), mrSidebarWin.ColorDark()),
- ColorFromAlphaColor(15, mrSidebarWin.ColorAnchor(), mrSidebarWin.ColorDark()));
- else
- aGradient = Gradient(GradientStyle::Linear,
- ColorFromAlphaColor(15, mrSidebarWin.ColorAnchor(), mrSidebarWin.ColorDark()),
- ColorFromAlphaColor(80, mrSidebarWin.ColorAnchor(), mrSidebarWin.ColorDark()));
- rRenderContext.DrawGradient(aRect, aGradient);
-
- //draw rect around button
- rRenderContext.SetFillColor();
- rRenderContext.SetLineColor(ColorFromAlphaColor(90, mrSidebarWin.ColorAnchor(), mrSidebarWin.ColorDark()));
+ bReplyVis = sAuthor != GetAuthor();
+ mxMenuButton->set_item_visible("reply", bReplyVis);
}
- rRenderContext.DrawRect(aRect);
-
- tools::Rectangle aSymbolRect(aRect);
- // 25% distance to the left and right button border
- const tools::Long nBorderDistanceLeftAndRight = ((aSymbolRect.GetWidth() * 250) + 500) / 1000;
- aSymbolRect.AdjustLeft(nBorderDistanceLeftAndRight );
- aSymbolRect.AdjustRight( -nBorderDistanceLeftAndRight );
- // 40% distance to the top button border
- const tools::Long nBorderDistanceTop = ((aSymbolRect.GetHeight() * 400) + 500) / 1000;
- aSymbolRect.AdjustTop(nBorderDistanceTop );
- // 15% distance to the bottom button border
- const tools::Long nBorderDistanceBottom = ((aSymbolRect.GetHeight() * 150) + 500) / 1000;
- aSymbolRect.AdjustBottom( -nBorderDistanceBottom );
- DecorationView aDecoView(&rRenderContext);
- aDecoView.DrawSymbol(aSymbolRect, SymbolType::SPIN_DOWN, (bHighContrast ? COL_WHITE : COL_BLACK));
+ mxMenuButton->set_item_visible("sep1", bReplyVis);
}
-void AnnotationMenuButton::KeyInput(const KeyEvent& rKeyEvt)
+IMPL_LINK(SwAnnotationWin, KeyInputHdl, const KeyEvent&, rKeyEvt, bool)
{
const vcl::KeyCode& rKeyCode = rKeyEvt.GetKeyCode();
if (rKeyCode.GetCode() == KEY_TAB)
{
- mrSidebarWin.ActivatePostIt();
- mrSidebarWin.GrabFocus();
- }
- else
- {
- MenuButton::KeyInput(rKeyEvt);
+ ActivatePostIt();
+ GrabFocus();
+ return true;
}
+ return false;
}
} // end of namespace sw::annotation
diff --git a/sw/source/uibase/docvw/AnnotationMenuButton.hxx b/sw/source/uibase/docvw/AnnotationMenuButton.hxx
deleted file mode 100644
index 8734cd9565b8..000000000000
--- a/sw/source/uibase/docvw/AnnotationMenuButton.hxx
+++ /dev/null
@@ -1,51 +0,0 @@
-/* -*- 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 .
- */
-
-#pragma once
-
-#include <vcl/menubtn.hxx>
-
-namespace sw::annotation {
- class SwAnnotationWin;
-}
-
-namespace sw::annotation {
-
-class AnnotationMenuButton : public MenuButton
-{
- public:
- AnnotationMenuButton( sw::annotation::SwAnnotationWin& rSidebarWin );
- virtual ~AnnotationMenuButton() override;
- virtual void dispose() override;
-
- // override MenuButton methods
- virtual void Select() override;
-
- // override vcl::Window methods
- virtual void MouseButtonDown( const MouseEvent& rMEvt ) override;
- virtual void Paint( vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect ) override;
- virtual void KeyInput( const KeyEvent& rKeyEvt ) override;
-
- private:
- sw::annotation::SwAnnotationWin& mrSidebarWin;
-};
-
-} // end of namespace sw::annotation
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sw/source/uibase/docvw/AnnotationWin.cxx b/sw/source/uibase/docvw/AnnotationWin.cxx
index 45afbc5c1f0a..34edc64425f5 100644
--- a/sw/source/uibase/docvw/AnnotationWin.cxx
+++ b/sw/source/uibase/docvw/AnnotationWin.cxx
@@ -19,7 +19,6 @@
#include <AnnotationWin.hxx>
-#include "AnnotationMenuButton.hxx"
#include <PostItMgr.hxx>
#include <strings.hrc>
@@ -90,16 +89,10 @@ SwAnnotationWin::SwAnnotationWin( SwEditWin& rEditWin,
SwPostItMgr& aMgr,
SwSidebarItem& rSidebarItem,
SwFormatField* aField )
- : Window(&rEditWin)
- , maBuilder(nullptr, AllSettings::GetUIRootDir(), "modules/swriter/ui/annotationmenu.ui", "")
+ : InterimItemWindow(&rEditWin, "modules/swriter/ui/annotation.ui", "Annotation")
, mrMgr(aMgr)
, mrView(rEditWin.GetView())
, mnEventId(nullptr)
- , mpSidebarTextControl(nullptr)
- , mpVScrollbar(nullptr)
- , mpMetadataAuthor(nullptr)
- , mpMetadataDate(nullptr)
- , mpMenuButton(nullptr)
, mColorAnchor()
, mColorDark()
, mColorLight()
@@ -118,10 +111,11 @@ SwAnnotationWin::SwAnnotationWin( SwEditWin& rEditWin,
, mpAnchorFrame(rSidebarItem.maLayoutInfo.mpAnchorFrame)
, mpFormatField(aField)
, mpField( static_cast<SwPostItField*>(aField->GetField()))
- , mpButtonPopup(nullptr)
{
set_id("Comment"+OUString::number(mpField->GetPostItId()));
+ m_xContainer->connect_mouse_move(LINK(this, SwAnnotationWin, MouseMoveHdl));
+
mpShadow = sidebarwindows::ShadowOverlayObject::CreateShadowOverlayObject( mrView );
if ( mpShadow )
{
@@ -145,9 +139,6 @@ SwAnnotationWin::~SwAnnotationWin()
void SwAnnotationWin::dispose()
{
- mpButtonPopup.clear();
- maBuilder.disposeBuilder();
-
if (IsDisposed())
return;
@@ -156,55 +147,28 @@ void SwAnnotationWin::dispose()
Disable();
- if ( mpSidebarTextControl )
- {
- if ( mpOutlinerView )
- {
- mpOutlinerView->SetWindow( nullptr );
- }
- }
- mpSidebarTextControl.disposeAndClear();
-
- mpOutlinerView.reset();
- mpOutliner.reset();
-
- if (mpMetadataAuthor)
- {
- mpMetadataAuthor->RemoveEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
- }
- mpMetadataAuthor.disposeAndClear();
-
- if (mpMetadataResolved)
- {
- mpMetadataResolved->RemoveEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
- }
- mpMetadataResolved.disposeAndClear();
-
- if (mpMetadataDate)
- {
- mpMetadataDate->RemoveEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
- }
- mpMetadataDate.disposeAndClear();
-
- if (mpVScrollbar)
- {
- mpVScrollbar->RemoveEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
- }
- mpVScrollbar.disposeAndClear();
+ mxSidebarTextControlWin.reset();
+ mxSidebarTextControl.reset();
- RemoveEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
+ mxMetadataAuthor.reset();
+ mxMetadataResolved.reset();
+ mxMetadataDate.reset();
+ mxVScrollbar.reset();
mpAnchor.reset();
mpShadow.reset();
mpTextRangeOverlay.reset();
- mpMenuButton.disposeAndClear();
+ mxMenuButton.reset();
if (mnEventId)
Application::RemoveUserEvent( mnEventId );
- vcl::Window::dispose();
+ mpOutliner.reset();
+ mpOutlinerView.reset();
+
+ InterimItemWindow::dispose();
}
void SwAnnotationWin::SetPostItText()
@@ -254,9 +218,9 @@ void SwAnnotationWin::SetResolved(bool resolved)
mpTextRangeOverlay.reset();
if(IsResolved())
- mpMetadataResolved->Show();
+ mxMetadataResolved->show();
else
- mpMetadataResolved->Hide();
+ mxMetadataResolved->hide();
if(IsResolved() != oldState)
mbResolvedStateUpdated = true;
@@ -437,21 +401,6 @@ sal_uInt32 SwAnnotationWin::CountFollowing()
return aCount - 1;
}
-VclPtr<MenuButton> SwAnnotationWin::CreateMenuButton()
-{
- mpButtonPopup = maBuilder.get_menu("menu");
- sal_uInt16 nByAuthorId = mpButtonPopup->GetItemId("deleteby");
- OUString aText = mpButtonPopup->GetItemText(nByAuthorId);
- SwRewriter aRewriter;
- aRewriter.AddRule(UndoArg1,GetAuthor());
- aText = aRewriter.Apply(aText);
- mpButtonPopup->SetItemText(nByAuthorId, aText);
- VclPtrInstance<AnnotationMenuButton> pMenuButton( *this );
- pMenuButton->SetPopupMenu( mpButtonPopup );
- pMenuButton->Show();
- return pMenuButton;
-}
-
void SwAnnotationWin::InitAnswer(OutlinerParaObject const * pText)
{
// If tiled annotations is off in lok case, skip adding additional reply text.
diff --git a/sw/source/uibase/docvw/AnnotationWin2.cxx b/sw/source/uibase/docvw/AnnotationWin2.cxx
index d093ed61508b..36f179869e45 100644
--- a/sw/source/uibase/docvw/AnnotationWin2.cxx
+++ b/sw/source/uibase/docvw/AnnotationWin2.cxx
@@ -27,7 +27,6 @@
#include <IDocumentUndoRedo.hxx>
#include <basegfx/range/b2drange.hxx>
#include "SidebarTxtControl.hxx"
-#include "SidebarScrollBar.hxx"
#include "AnchorOverlayObject.hxx"
#include "ShadowOverlayObject.hxx"
#include "OverlayRanges.hxx"
@@ -56,7 +55,6 @@
#include <vcl/event.hxx>
#include <vcl/scrbar.hxx>
#include <vcl/svapp.hxx>
-#include <vcl/menubtn.hxx>
#include <vcl/settings.hxx>
#include <vcl/ptrstyle.hxx>
#include <vcl/uitest/logger.hxx>
@@ -69,12 +67,14 @@
#include <doc.hxx>
#include <swmodule.hxx>
+#include <SwRewriter.hxx>
#include <txtannotationfld.hxx>
#include <ndtxt.hxx>
#include <drawinglayer/processor2d/baseprocessor2d.hxx>
#include <drawinglayer/processor2d/processorfromoutputdevice.hxx>
#include <unotools/localedatawrapper.hxx>
+#include <unotools/syslocale.hxx>
#include <memory>
#include <comphelper/lok.hxx>
@@ -94,62 +94,6 @@ void collectUIInformation( const OUString& aevent , const OUString& aID )
UITestLogger::getInstance().logEvent(aDescription);
}
-/// Translate absolute <-> relative twips: LOK wants absolute coordinates as output and gives absolute coordinates as input.
-void lcl_translateTwips(vcl::Window const & rParent, vcl::Window& rChild, MouseEvent* pMouseEvent)
-{
- // Set map mode, so that callback payloads will contain absolute coordinates instead of relative ones.
- Point aOffset(rChild.GetOutOffXPixel() - rParent.GetOutOffXPixel(), rChild.GetOutOffYPixel() - rParent.GetOutOffYPixel());
- if (!rChild.IsMapModeEnabled())
- {
- MapMode aMapMode(rChild.GetMapMode());
- aMapMode.SetMapUnit(MapUnit::MapTwip);
- aMapMode.SetScaleX(rParent.GetMapMode().GetScaleX());
- aMapMode.SetScaleY(rParent.GetMapMode().GetScaleY());
- rChild.SetMapMode(aMapMode);
- rChild.EnableMapMode();
- }
- aOffset = rChild.PixelToLogic(aOffset);
- MapMode aMapMode(rChild.GetMapMode());
- aMapMode.SetOrigin(aOffset);
- aMapMode.SetMapUnit(rParent.GetMapMode().GetMapUnit());
- rChild.SetMapMode(aMapMode);
- rChild.EnableMapMode(false);
-
- if (pMouseEvent)
- {
- // Set event coordinates, so they contain relative coordinates instead of absolute ones.
- Point aPos = pMouseEvent->GetPosPixel();
- aPos.Move(-aOffset.getX(), -aOffset.getY());
- MouseEvent aMouseEvent(aPos, pMouseEvent->GetClicks(), pMouseEvent->GetMode(), pMouseEvent->GetButtons(), pMouseEvent->GetModifier());
- *pMouseEvent = aMouseEvent;
- }
-}
-
-/// Decide which one from the children of rParent should get rMouseEvent.
-vcl::Window* lcl_getHitWindow(sw::annotation::SwAnnotationWin& rParent, const MouseEvent& rMouseEvent)
-{
- vcl::Window* pRet = nullptr;
-
- rParent.EditWin().Push(PushFlags::MAPMODE);
- rParent.EditWin().EnableMapMode();
- for (sal_Int16 i = rParent.GetChildCount() - 1; i >= 0; --i)
- {
- vcl::Window* pChild = rParent.GetChild(i);
-
- Point aPosition(rParent.GetPosPixel());
- aPosition.Move(pChild->GetPosPixel().getX(), pChild->GetPosPixel().getY());
- Size aSize(rParent.GetSizePixel());
- tools::Rectangle aRectangleLogic(rParent.EditWin().PixelToLogic(aPosition), rParent.EditWin().PixelToLogic(aSize));
- if (aRectangleLogic.IsInside(rMouseEvent.GetPosPixel()))
- {
- pRet = pChild;
- break;
- }
- }
- rParent.EditWin().Pop();
- return pRet;
-}
-
}
namespace sw::annotation {
@@ -160,80 +104,22 @@ namespace sw::annotation {
#define POSTIT_META_FIELD_HEIGHT sal_Int32(15)
#define POSTIT_MINIMUMSIZE_WITHOUT_META 50
-
-void SwAnnotationWin::Paint(vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect)
+void SwAnnotationWin::PaintTile(vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect)
{
- Window::Paint(rRenderContext, rRect);
+ bool bMenuButtonVisible = mxMenuButton->get_visible();
+ // No point in showing this button till click on it are not handled.
+ if (bMenuButtonVisible)
+ mxMenuButton->hide();
- if (!mpMetadataAuthor->IsVisible())
- return;
-
- //draw left over space
+ // draw left over space
if (Application::GetSettings().GetStyleSettings().GetHighContrastMode())
- {
rRenderContext.SetFillColor(COL_BLACK);
- }
else
- {
rRenderContext.SetFillColor(mColorDark);
- }
-
- sal_uInt32 boxHeight = mpMetadataAuthor->GetSizePixel().Height() + mpMetadataDate->GetSizePixel().Height();
- boxHeight += IsResolved() ? mpMetadataResolved->GetSizePixel().Height() : 0;
-
rRenderContext.SetLineColor();
- tools::Rectangle aRectangle(Point(mpMetadataAuthor->GetPosPixel().X() + mpMetadataAuthor->GetSizePixel().Width(),
- mpMetadataAuthor->GetPosPixel().Y()),
- Size(GetMetaButtonAreaWidth(), boxHeight));
-
- if (comphelper::LibreOfficeKit::isActive())
- aRectangle = rRect;
- else
- aRectangle = PixelToLogic(aRectangle);
- rRenderContext.DrawRect(aRectangle);
-}
-
-void SwAnnotationWin::PaintTile(vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect)
-{
- Paint(rRenderContext, rRect);
-
- for (sal_uInt16 i = 0; i < GetChildCount(); ++i)
- {
- vcl::Window* pChild = GetChild(i);
-
- // No point in showing this button till click on it are not handled.
- if (pChild == mpMenuButton.get())
- continue;
-
- if (!pChild->IsVisible())
- continue;
-
- rRenderContext.Push(PushFlags::MAPMODE);
- Point aOffset(PixelToLogic(pChild->GetPosPixel()));
- MapMode aMapMode(rRenderContext.GetMapMode());
- aMapMode.SetOrigin(aMapMode.GetOrigin() + aOffset);
- rRenderContext.SetMapMode(aMapMode);
-
- bool bPopChild = false;
- if (pChild->GetMapMode().GetMapUnit() != rRenderContext.GetMapMode().GetMapUnit())
- {
- // This is needed for the scrollbar that has its map unit in pixels.
- pChild->Push(PushFlags::MAPMODE);
- bPopChild = true;
- pChild->EnableMapMode();
- aMapMode = pChild->GetMapMode();
- aMapMode.SetMapUnit(rRenderContext.GetMapMode().GetMapUnit());
- aMapMode.SetScaleX(rRenderContext.GetMapMode().GetScaleX());
- aMapMode.SetScaleY(rRenderContext.GetMapMode().GetScaleY());
- pChild->SetMapMode(aMapMode);
- }
+ rRenderContext.DrawRect(rRect);
- pChild->Paint(rRenderContext, rRect);
-
- if (bPopChild)
- pChild->Pop();
- rRenderContext.Pop();
- }
+ m_xContainer->draw(rRenderContext, rRect.TopLeft(), GetSizePixel());
const drawinglayer::geometry::ViewInformation2D aViewInformation;
std::unique_ptr<drawinglayer::processor2d::BaseProcessor2D> pProcessor(drawinglayer::processor2d::createBaseProcessor2DFromOutputDevice(rRenderContext, aViewInformation));
@@ -250,6 +136,9 @@ void SwAnnotationWin::PaintTile(vcl::RenderContext& rRenderContext, const tools:
rRenderContext.Push(PushFlags::NONE);
pProcessor.reset();
rRenderContext.Push(PushFlags::NONE);
+
+ if (bMenuButtonVisible)
+ mxMenuButton->show();
}
bool SwAnnotationWin::IsHitWindow(const Point& rPointLogic)
@@ -260,62 +149,66 @@ bool SwAnnotationWin::IsHitWindow(const Point& rPointLogic)
void SwAnnotationWin::SetCursorLogicPosition(const Point& rPosition, bool bPoint, bool bClearMark)
{
- mpSidebarTextControl->Push(PushFlags::MAPMODE);
- MouseEvent aMouseEvent(rPosition);
- lcl_translateTwips(EditWin(), *mpSidebarTextControl, &aMouseEvent);
- Point aPosition(aMouseEvent.GetPosPixel());
-
- EditView& rEditView = GetOutlinerView()->GetEditView();
- rEditView.SetCursorLogicPosition(aPosition, bPoint, bClearMark);
-
- mpSidebarTextControl->Pop();
+ mxSidebarTextControl->SetCursorLogicPosition(rPosition, bPoint, bClearMark);
}
-void SwAnnotationWin::Draw(OutputDevice* pDev, const Point& rPt, DrawFlags nInFlags)
+void SwAnnotationWin::DrawForPage(OutputDevice* pDev, const Point& rPt)
{
+ pDev->Push();
+
+ pDev->SetFillColor(mColorDark);
+ pDev->SetLineColor();
+
+ pDev->SetTextColor(mColorAnchor);
+ vcl::Font aFont = maLabelFont;
+ aFont.SetFontHeight(aFont.GetFontHeight() * 20);
+ pDev->SetFont(aFont);
+
Size aSz = PixelToLogic(GetSizePixel());
+ pDev->DrawRect(tools::Rectangle(rPt, aSz));
- if (mpMetadataAuthor->IsVisible() )
+ if (mxMetadataAuthor->get_visible())
{
- pDev->SetFillColor(mColorDark);
- pDev->SetLineColor();
- pDev->DrawRect( tools::Rectangle( rPt, aSz ) );
- }
+ int x, y, width, height;
+ mxMetadataAuthor->get_extents_relative_to(*m_xContainer, x, y, width, height);
+ Point aPos(rPt + PixelToLogic(Point(x, y)));
+ Size aSize(PixelToLogic(Size(width, height)));
- if (mpMetadataAuthor->IsVisible())
- {
- vcl::Font aOrigFont(mpMetadataAuthor->GetControlFont());
- Point aPos(PixelToLogic(mpMetadataAuthor->GetPosPixel()));
- aPos += rPt;
- vcl::Font aFont( mpMetadataAuthor->GetSettings().GetStyleSettings().GetLabelFont() );
- mpMetadataAuthor->SetControlFont( aFont );
- mpMetadataAuthor->Draw(pDev, aPos, nInFlags);
- mpMetadataAuthor->SetControlFont( aOrigFont );
+ pDev->Push(PushFlags::CLIPREGION);
+ pDev->IntersectClipRegion(tools::Rectangle(aPos, aSize));
+ pDev->DrawText(aPos, mxMetadataAuthor->get_label());
+ pDev->Pop();
}
- if (mpMetadataDate->IsVisible())
+// m_xContainer->draw(*pDev, rPt, GetSizePixel());
+
+ if (mxMetadataDate->get_visible())
{
- vcl::Font aOrigFont(mpMetadataDate->GetControlFont());
- Point aPos(PixelToLogic(mpMetadataDate->GetPosPixel()));
- aPos += rPt;
- vcl::Font aFont( mpMetadataDate->GetSettings().GetStyleSettings().GetLabelFont() );
- mpMetadataDate->SetControlFont( aFont );
- mpMetadataDate->Draw(pDev, aPos, nInFlags);
- mpMetadataDate->SetControlFont( aOrigFont );
+ int x, y, width, height;
+ mxMetadataDate->get_extents_relative_to(*m_xContainer, x, y, width, height);
+ Point aPos(rPt + PixelToLogic(Point(x, y)));
+ Size aSize(PixelToLogic(Size(width, height)));
+
+ pDev->Push(PushFlags::CLIPREGION);
+ pDev->IntersectClipRegion(tools::Rectangle(aPos, aSize));
+ pDev->DrawText(aPos, mxMetadataDate->get_label());
+ pDev->Pop();
}
- if (mpMetadataResolved->IsVisible())
+ if (mxMetadataResolved->get_visible())
{
- vcl::Font aOrigFont(mpMetadataResolved->GetControlFont());
- Point aPos(PixelToLogic(mpMetadataResolved->GetPosPixel()));
- aPos += rPt;
- vcl::Font aFont( mpMetadataResolved->GetSettings().GetStyleSettings().GetLabelFont() );
- mpMetadataResolved->SetControlFont( aFont );
- mpMetadataResolved->Draw(pDev, aPos, nInFlags);
- mpMetadataResolved->SetControlFont( aOrigFont );
+ int x, y, width, height;
+ mxMetadataResolved->get_extents_relative_to(*m_xContainer, x, y, width, height);
+ Point aPos(rPt + PixelToLogic(Point(x, y)));
+ Size aSize(PixelToLogic(Size(width, height)));
+
+ pDev->Push(PushFlags::CLIPREGION);
+ pDev->IntersectClipRegion(tools::Rectangle(aPos, aSize));
+ pDev->DrawText(aPos, mxMetadataResolved->get_label());
+ pDev->Pop();
}
- mpSidebarTextControl->Draw(pDev, rPt, nInFlags);
+ mxSidebarTextControl->DrawForPage(pDev, rPt);
const drawinglayer::geometry::ViewInformation2D aNewViewInfos;
std::unique_ptr<drawinglayer::processor2d::BaseProcessor2D> pProcessor(
@@ -328,85 +221,17 @@ void SwAnnotationWin::Draw(OutputDevice* pDev, const Point& rPt, DrawFlags nInFl
pProcessor->process(mpTextRangeOverlay->getOverlayObjectPrimitive2DSequence());
pProcessor.reset();
- if (!mpVScrollbar->IsVisible())
- return;
-
- // if there is a scrollbar shown, draw "..." to indicate the comment isn't
- // completely shown
- vcl::Font aOrigFont(mpMetadataDate->GetControlFont());
- Color aOrigBg( mpMetadataDate->GetControlBackground() );
- OUString sOrigText(mpMetadataDate->GetText());
-
- Point aPos(PixelToLogic(mpMenuButton->GetPosPixel()));
- aPos += rPt;
-
- vcl::Font aFont( mpMetadataDate->GetSettings().GetStyleSettings().GetLabelFont() );
- mpMetadataDate->SetControlFont( aFont );
- mpMetadataDate->SetControlBackground( Color(0xFFFFFF) );
- mpMetadataDate->SetText("...");
- Size aOrigSize = mpMetadataDate->GetSizePixel();
- mpMetadataDate->SetSizePixel(mpMenuButton->GetSizePixel());
- mpMetadataDate->Draw(pDev, aPos, nInFlags);
- mpMetadataDate->SetSizePixel(aOrigSize);
-
- mpMetadataDate->SetText(sOrigText);
- mpMetadataDate->SetControlFont( aOrigFont );
- mpMetadataDate->SetControlBackground( aOrigBg );
-}
-
-void SwAnnotationWin::KeyInput(const KeyEvent& rKeyEvent)
-{
- if (mpSidebarTextControl)
+ if (mxVScrollbar->get_vpolicy() != VclPolicyType::NEVER)
{
- mpSidebarTextControl->Push(PushFlags::MAPMODE);
- lcl_translateTwips(EditWin(), *mpSidebarTextControl, nullptr);
-
- mpSidebarTextControl->KeyInput(rKeyEvent);
-
- mpSidebarTextControl->Pop();
- }
-}
-
-void SwAnnotationWin::MouseMove(const MouseEvent& rMouseEvent)
-{
- if (vcl::Window* pHit = lcl_getHitWindow(*this, rMouseEvent))
- {
- pHit->Push(PushFlags::MAPMODE);
- MouseEvent aMouseEvent(rMouseEvent);
- lcl_translateTwips(EditWin(), *pHit, &aMouseEvent);
-
- pHit->MouseMove(aMouseEvent);
-
- pHit->Pop();
+ // if there is a scrollbar shown, draw "..." to indicate the comment isn't
+ // completely shown
+ int x, y, width, height;
+ mxMenuButton->get_extents_relative_to(*m_xContainer, x, y, width, height);
+ Point aPos(rPt + PixelToLogic(Point(x, y)));
+ pDev->DrawText(aPos, "...");
}
-}
-
-void SwAnnotationWin::MouseButtonDown(const MouseEvent& rMouseEvent)
-{
- if (vcl::Window* pHit = lcl_getHitWindow(*this, rMouseEvent))
- {
- pHit->Push(PushFlags::MAPMODE);
- MouseEvent aMouseEvent(rMouseEvent);
- lcl_translateTwips(EditWin(), *pHit, &aMouseEvent);
-
- pHit->MouseButtonDown(aMouseEvent);
-
- pHit->Pop();
- }
-}
-
-void SwAnnotationWin::MouseButtonUp(const MouseEvent& rMouseEvent)
-{
- if (vcl::Window* pHit = lcl_getHitWindow(*this, rMouseEvent))
- {
- pHit->Push(PushFlags::MAPMODE);
- MouseEvent aMouseEvent(rMouseEvent);
- lcl_translateTwips(EditWin(), *pHit, &aMouseEvent);
-
- pHit->MouseButtonUp(aMouseEvent);
- pHit->Pop();
- }
+ pDev->Pop();
}
void SwAnnotationWin::SetPosSizePixelRect(tools::Long nX, tools::Long nY, tools::Long nWidth, tools::Long nHeight,
@@ -458,63 +283,36 @@ SfxItemSet SwAnnotationWin::DefaultItem()
void SwAnnotationWin::InitControls()
{
- AddEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
+ // window controls for author and date
+ mxMetadataAuthor = m_xBuilder->weld_label("author");
+ mxMetadataAuthor->set_accessible_name( SwResId( STR_ACCESS_ANNOTATION_AUTHOR_NAME ) );
+ mxMetadataAuthor->set_direction(AllSettings::GetLayoutRTL());
- // actual window which holds the user text
- mpSidebarTextControl = VclPtr<SidebarTextControl>::Create( *this,
- WB_NODIALOGCONTROL,
- mrView, mrMgr );
- mpSidebarTextControl->SetPointer(PointerStyle::Text);
+ maLabelFont = Application::GetSettings().GetStyleSettings().GetLabelFont();
+ maLabelFont.SetFontHeight(8);
- // window controls for author and date
- mpMetadataAuthor = VclPtr<FixedText>::Create(this);
- mpMetadataAuthor->SetAccessibleName( SwResId( STR_ACCESS_ANNOTATION_AUTHOR_NAME ) );
- mpMetadataAuthor->EnableRTL(AllSettings::GetLayoutRTL());
- mpMetadataAuthor->AddEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
// we should leave this setting alone, but for this we need a better layout algo
// with variable meta size height
- {
- AllSettings aSettings = mpMetadataAuthor->GetSettings();
- StyleSettings aStyleSettings = aSettings.GetStyleSettings();
- vcl::Font aFont = aStyleSettings.GetLabelFont();
- aFont.SetFontHeight(8);
- aStyleSettings.SetLabelFont(aFont);
- aSettings.SetStyleSettings(aStyleSettings);
- mpMetadataAuthor->SetSettings(aSettings);
- }
+ mxMetadataAuthor->set_font(maLabelFont);
+
+ mxMetadataDate = m_xBuilder->weld_label("date");
+ mxMetadataDate->set_accessible_name( SwResId( STR_ACCESS_ANNOTATION_DATE_NAME ) );
+ mxMetadataDate->set_direction(AllSettings::GetLayoutRTL());
+ mxMetadataDate->connect_mouse_move(LINK(this, SwAnnotationWin, MouseMoveHdl));
- mpMetadataDate = VclPtr<FixedText>::Create(this);
- mpMetadataDate->SetAccessibleName( SwResId( STR_ACCESS_ANNOTATION_DATE_NAME ) );
- mpMetadataDate->EnableRTL(AllSettings::GetLayoutRTL());
- mpMetadataDate->AddEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
// we should leave this setting alone, but for this we need a better layout algo
// with variable meta size height
- {
- AllSettings aSettings = mpMetadataDate->GetSettings();
- StyleSettings aStyleSettings = aSettings.GetStyleSettings();
- vcl::Font aFont = aStyleSettings.GetLabelFont();
- aFont.SetFontHeight(8);
- aStyleSettings.SetLabelFont(aFont);
- aSettings.SetStyleSettings(aStyleSettings);
- mpMetadataDate->SetSettings(aSettings);
- }
+ mxMetadataDate->set_font(maLabelFont);
+
+ mxMetadataResolved = m_xBuilder->weld_label("resolved");
+ mxMetadataResolved->set_accessible_name( SwResId( STR_ACCESS_ANNOTATION_RESOLVED_NAME ) );
+ mxMetadataResolved->set_direction(AllSettings::GetLayoutRTL());
+ mxMetadataResolved->connect_mouse_move(LINK(this, SwAnnotationWin, MouseMoveHdl));
- mpMetadataResolved = VclPtr<FixedText>::Create(this);
- mpMetadataResolved->SetAccessibleName( SwResId( STR_ACCESS_ANNOTATION_RESOLVED_NAME ) );
- mpMetadataResolved->EnableRTL(AllSettings::GetLayoutRTL());
- mpMetadataResolved->AddEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
// we should leave this setting alone, but for this we need a better layout algo
// with variable meta size height
- {
- AllSettings aSettings = mpMetadataResolved->GetSettings();
- StyleSettings aStyleSettings = aSettings.GetStyleSettings();
- vcl::Font aFont = aStyleSettings.GetLabelFont();
- aFont.SetFontHeight(8);
- aStyleSettings.SetLabelFont(aFont);
- aSettings.SetStyleSettings(aStyleSettings);
- mpMetadataResolved->SetSettings(aSettings);
- mpMetadataResolved->SetText( SwResId( STR_ACCESS_ANNOTATION_RESOLVED_NAME ) );
- }
+ mxMetadataResolved->set_font(maLabelFont);
+ mxMetadataResolved->set_label(SwResId(STR_ACCESS_ANNOTATION_RESOLVED_NAME));
SwDocShell* aShell = mrView.GetDocShell();
mpOutliner.reset(new Outliner(&aShell->GetPool(),OutlinerMode::TextObject));
@@ -522,21 +320,28 @@ void SwAnnotationWin::InitControls()
mpOutliner->SetUpdateMode( true );
Rescale();
- mpSidebarTextControl->EnableRTL( false );
- mpOutlinerView.reset(new OutlinerView ( mpOutliner.get(), mpSidebarTextControl ));
+ mpOutlinerView.reset(new OutlinerView(mpOutliner.get(), nullptr));
+ mpOutliner->InsertView(mpOutlinerView.get());
+
+ //create Scrollbars
+ mxVScrollbar = m_xBuilder->weld_scrolled_window("scrolledwindow", true);
+
+ // actual window which holds the user text
+ mxSidebarTextControl.reset(new SidebarTextControl(*this, mrView, mrMgr));
+ mxSidebarTextControlWin.reset(new weld::CustomWeld(*m_xBuilder, "editview", *mxSidebarTextControl));
+ mxSidebarTextControl->SetPointer(PointerStyle::Text);
+
mpOutlinerView->SetBackgroundColor(COL_TRANSPARENT);
- mpOutliner->InsertView(mpOutlinerView.get() );
mpOutlinerView->SetOutputArea( PixelToLogic( tools::Rectangle(0,0,1,1) ) );
mpOutlinerView->SetAttribs(DefaultItem());
- //create Scrollbars
- mpVScrollbar = VclPtr<SidebarScrollBar>::Create(*this, WB_3DLOOK |WB_VSCROLL|WB_DRAG, mrView);
- mpVScrollbar->EnableNativeWidget(false);
- mpVScrollbar->EnableRTL( false );
- mpVScrollbar->SetScrollHdl(LINK(this, SwAnnotationWin, ScrollHdl));
- mpVScrollbar->EnableDrag();
- mpVScrollbar->AddEventListener( LINK( this, SwAnnotationWin, WindowEventListener ) );
+ mxVScrollbar->set_direction(false);
+ mxVScrollbar->connect_vadjustment_changed(LINK(this, SwAnnotationWin, ScrollHdl));
+ mxVScrollbar->connect_mouse_move(LINK(this, SwAnnotationWin, MouseMoveHdl));
+
+ mxMenuButton = m_xBuilder->weld_menu_button("menubutton");
+ mxMenuButton->set_size_request(METABUTTON_WIDTH, METABUTTON_HEIGHT);
const SwViewOption* pVOpt = mrView.GetWrtShellPtr()->GetViewOptions();
EEControlBits nCntrl = mpOutliner->GetControlWord();
@@ -559,18 +364,32 @@ void SwAnnotationWin::InitControls()
CheckMetaText();
- mpMenuButton = CreateMenuButton();
+ // expand %1 "Author"
+ OUString aText = mxMenuButton->get_item_label("deleteby");
+ SwRewriter aRewriter;
+ aRewriter.AddRule(UndoArg1, GetAuthor());
+ aText = aRewriter.Apply(aText);
+ mxMenuButton->set_item_label("deleteby", aText);
+
+ mxMenuButton->set_accessible_name(SwResId(STR_ACCESS_ANNOTATION_BUTTON_NAME));
+ mxMenuButton->set_accessible_description(SwResId(STR_ACCESS_ANNOTATION_BUTTON_DESC));
+ mxMenuButton->set_tooltip_text(SwResId(STR_ACCESS_ANNOTATION_BUTTON_DESC));
+
+ mxMenuButton->connect_toggled(LINK(this, SwAnnotationWin, ToggleHdl));
+ mxMenuButton->connect_selected(LINK(this, SwAnnotationWin, SelectHdl));
+ mxMenuButton->connect_key_press(LINK(this, SwAnnotationWin, KeyInputHdl));
+ mxMenuButton->connect_mouse_move(LINK(this, SwAnnotationWin, MouseMoveHdl));
SetLanguage(GetLanguage());
GetOutlinerView()->StartSpeller();
SetPostItText();
mpOutliner->CompleteOnlineSpelling();
- mpSidebarTextControl->Show();
- mpMetadataAuthor->Show();
- mpMetadataDate->Show();
- if(IsResolved()) { mpMetadataResolved->Show(); }
- mpVScrollbar->Show();
+ mxSidebarTextControl->Show();
+ mxMetadataAuthor->show();
+ mxMetadataDate->show();
+ mxMetadataResolved->set_visible(IsResolved());
+ mxVScrollbar->set_vpolicy(VclPolicyType::ALWAYS);
}
void SwAnnotationWin::CheckMetaText()
@@ -586,9 +405,9 @@ void SwAnnotationWin::CheckMetaText()
{
sMeta = OUString::Concat(sMeta.subView(0, 20)) + "...";
}
- if ( mpMetadataAuthor->GetText() != sMeta )
+ if ( mxMetadataAuthor->get_label() != sMeta )
{
- mpMetadataAuthor->SetText(sMeta);
+ mxMetadataAuthor->set_label(sMeta);
}
Date aDate = GetDate();
@@ -604,10 +423,15 @@ void SwAnnotationWin::CheckMetaText()
{
sMeta += " " + rLocalData.getTime( GetTime(),false );
}
- if ( mpMetadataDate->GetText() != sMeta )
+ if ( mxMetadataDate->get_label() != sMeta )
{
- mpMetadataDate->SetText(sMeta);
+ mxMetadataDate->set_label(sMeta);
}
+
+ std::size_t aIndex = SW_MOD()->InsertRedlineAuthor(GetAuthor());
+ SetColor( SwPostItMgr::GetColorDark(aIndex),
+ SwPostItMgr::GetColorLight(aIndex),
+ SwPostItMgr::GetColorAnchor(aIndex));
}
void SwAnnotationWin::Rescale()
@@ -624,29 +448,18 @@ void SwAnnotationWin::Rescale()
aMode.SetOrigin( Point() );
mpOutliner->SetRefMapMode( aMode );
SetMapMode( aMode );
- mpSidebarTextControl->SetMapMode( aMode );
const Fraction& rFraction = mrView.GetWrtShellPtr()->GetOut()->GetMapMode().GetScaleY();
- if ( mpMetadataAuthor )
- {
- vcl::Font aFont( mpMetadataAuthor->GetSettings().GetStyleSettings().GetLabelFont() );
- sal_Int32 nHeight = tools::Long(aFont.GetFontHeight() * rFraction);
- aFont.SetFontHeight( nHeight );
- mpMetadataAuthor->SetControlFont( aFont );
- }
- if ( mpMetadataDate )
- {
- vcl::Font aFont( mpMetadataDate->GetSettings().GetStyleSettings().GetLabelFont() );
- sal_Int32 nHeight = tools::Long(aFont.GetFontHeight() * rFraction);
- aFont.SetFontHeight( nHeight );
- mpMetadataDate->SetControlFont( aFont );
- }
- if ( mpMetadataResolved )
- {
- vcl::Font aFont( mpMetadataResolved->GetSettings().GetStyleSettings().GetLabelFont() );
- sal_Int32 nHeight = tools::Long(aFont.GetFontHeight() * rFraction);
- aFont.SetFontHeight( nHeight );
- mpMetadataResolved->SetControlFont( aFont );
- }
+
+ vcl::Font aFont = maLabelFont;
+ sal_Int32 nHeight = tools::Long(aFont.GetFontHeight() * rFraction);
+ aFont.SetFontHeight( nHeight );
+
+ if (mxMetadataAuthor)
+ mxMetadataAuthor->set_font(aFont);
+ if (mxMetadataDate)
+ mxMetadataDate->set_font(aFont);
+ if (mxMetadataResolved)
+ mxMetadataResolved->set_font(aFont);
}
void SwAnnotationWin::SetPosAndSize()
@@ -658,23 +471,7 @@ void SwAnnotationWin::SetPosAndSize()
bChange = true;
SetSizePixel(mPosSize.GetSize());
- if (comphelper::LibreOfficeKit::isActive())
- {
- // Position is not yet set at VCL level, but the map mode should
- // contain the right origin to emit the correct cursor position.
- mpSidebarTextControl->Push(PushFlags::MAPMODE);
- Point aOffset(mPosSize.Left(), mPosSize.Top());
- aOffset = PixelToLogic(aOffset);
- MapMode aMapMode(mpSidebarTextControl->GetMapMode());
- aMapMode.SetOrigin(aOffset);
- mpSidebarTextControl->SetMapMode(aMapMode);
- mpSidebarTextControl->EnableMapMode(false);
- }
-
DoResize();
-
- if (comphelper::LibreOfficeKit::isActive())
- mpSidebarTextControl->Pop();
}
if (GetPosPixel().X() != mPosSize.Left() || (std::abs(GetPosPixel().Y() - mPosSize.Top()) > 5) )
@@ -890,37 +687,19 @@ void SwAnnotationWin::DoResize()
tools::ULong aWidth = GetSizePixel().Width();
aHeight -= GetMetaHeight();
- mpMetadataAuthor->Show();
- if(IsResolved()) { mpMetadataResolved->Show(); }
- mpMetadataDate->Show();
- unsigned int numFields = GetNumFields();
+ mxMetadataAuthor->show();
+ if(IsResolved()) { mxMetadataResolved->show(); }
+ mxMetadataDate->show();
+
if (aTextHeight > aHeight)
- { // we need vertical scrollbars and have to reduce the width
- aWidth -= GetScrollbarWidth();
- mpVScrollbar->Show();
- }
- else
{
- mpVScrollbar->Hide();
+ // we need vertical scrollbars and have to reduce the width
+ aWidth -= mxVScrollbar->get_vscroll_width();
+ mxVScrollbar->set_vpolicy(VclPolicyType::ALWAYS);
}
-
+ else
{
- const Size aSizeOfMetadataControls( GetSizePixel().Width() - GetMetaButtonAreaWidth(),
- GetMetaHeight()/numFields );
- mpMetadataAuthor->setPosSizePixel( 0,
- aHeight,
- aSizeOfMetadataControls.Width(),
- aSizeOfMetadataControls.Height() );
- mpMetadataDate->setPosSizePixel( 0,
- aHeight + aSizeOfMetadataControls.Height(),
- aSizeOfMetadataControls.Width(),
- aSizeOfMetadataControls.Height() );
- if(IsResolved()) {
- mpMetadataResolved->setPosSizePixel( 0,
- aHeight + aSizeOfMetadataControls.Height()*2,
- aSizeOfMetadataControls.Width(),
- aSizeOfMetadataControls.Height() );
- }
+ mxVScrollbar->set_vpolicy(VclPolicyType::NEVER);
}
mpOutliner->SetPaperSize( PixelToLogic( Size(aWidth,aHeight) ) ) ;
@@ -930,12 +709,13 @@ void SwAnnotationWin::DoResize()
mpOutlinerView->RegisterViewShell(&mrView);
}
- if (!mpVScrollbar->IsVisible())
+ if (mxVScrollbar->get_vpolicy() == VclPolicyType::NEVER)
{ // if we do not have a scrollbar anymore, we want to see the complete text
mpOutlinerView->SetVisArea( PixelToLogic( tools::Rectangle(0,0,aWidth,aHeight) ) );
}
tools::Rectangle aOutputArea = PixelToLogic(tools::Rectangle(0, 0, aWidth, aHeight));
mpOutlinerView->SetOutputArea(aOutputArea);
+ mpOutlinerView->ShowCursor(true, true);
// Don't leave an empty area at the bottom if we can move the text down.
tools::Long nMaxVisAreaTop = mpOutliner->GetTextHeight() - aOutputArea.GetHeight();
@@ -944,38 +724,29 @@ void SwAnnotationWin::DoResize()
GetOutlinerView()->Scroll(0, mpOutlinerView->GetVisArea().Top() - nMaxVisAreaTop);
}
- if (!AllSettings::GetLayoutRTL())
- {
- mpSidebarTextControl->setPosSizePixel(0, 0, aWidth, aHeight);
- mpVScrollbar->setPosSizePixel( aWidth, 0, GetScrollbarWidth(), aHeight);
- }
- else
- {
- mpSidebarTextControl->setPosSizePixel( ( aTextHeight > aHeight ? GetScrollbarWidth() : 0 ), 0,
- aWidth, aHeight);
- mpVScrollbar->setPosSizePixel( 0, 0, GetScrollbarWidth(), aHeight);
- }
+ int nUpper = mpOutliner->GetTextHeight();
+ int nCurrentDocPos = mpOutlinerView->GetVisArea().Top();
+ int nStepIncrement = mpOutliner->GetTextHeight() / 10;
+ int nPageIncrement = PixelToLogic(Size(0,aHeight)).Height() * 8 / 10;
+ int nPageSize = PixelToLogic(Size(0,aHeight)).Height();
+
+ /* limit the page size to below nUpper because gtk's gtk_scrolled_window_start_deceleration has
+ effectively...
+
+ lower = gtk_adjustment_get_lower
+ upper = gtk_adjustment_get_upper - gtk_adjustment_get_page_size
+
+ and requires that upper > lower or the deceleration animation never ends
+ */
+ nPageSize = std::min(nPageSize, nUpper);
- mpVScrollbar->SetVisibleSize( PixelToLogic(Size(0,aHeight)).Height() );
- mpVScrollbar->SetPageSize( PixelToLogic(Size(0,aHeight)).Height() * 8 / 10 );
- mpVScrollbar->SetLineSize( mpOutliner->GetTextHeight() / 10 );
- SetScrollbar();
- mpVScrollbar->SetRange( Range(0, mpOutliner->GetTextHeight()));
-
- //calculate rects for meta- button
- const Fraction& fx( GetMapMode().GetScaleX() );
- const Fraction& fy( GetMapMode().GetScaleY() );
-
- const Point aPos( mpMetadataAuthor->GetPosPixel());
- mpMenuButton->setPosSizePixel( tools::Long(aPos.X()+GetSizePixel().Width()-(METABUTTON_WIDTH+10)*fx),
- tools::Long(aPos.Y()+5*fy),
- tools::Long(METABUTTON_WIDTH*fx),
- tools::Long(METABUTTON_HEIGHT*fy) );
+ mxVScrollbar->vadjustment_configure(nCurrentDocPos, 0, nUpper,
+ nStepIncrement, nPageIncrement, nPageSize);
}
void SwAnnotationWin::SetSizePixel( const Size& rNewSize )
{
- Window::SetSizePixel(rNewSize);
+ InterimItemWindow::SetSizePixel(rNewSize);
if (mpShadow)
{
@@ -987,7 +758,7 @@ void SwAnnotationWin::SetSizePixel( const Size& rNewSize )
void SwAnnotationWin::SetScrollbar()
{
- mpVScrollbar->SetThumbPos(mpOutlinerView->GetVisArea().Top());
+ mxVScrollbar->vadjustment_set_value(mpOutlinerView->GetVisArea().Top());
}
void SwAnnotationWin::ResizeIfNecessary(tools::Long aOldHeight, tools::Long aNewHeight)
@@ -1037,41 +808,19 @@ void SwAnnotationWin::SetColor(Color aColorDark,Color aColorLight, Color aColorA
if ( Application::GetSettings().GetStyleSettings().GetHighContrastMode() )
return;
- {
- mpMetadataAuthor->SetControlBackground(mColorDark);
- AllSettings aSettings = mpMetadataAuthor->GetSettings();
- StyleSettings aStyleSettings = aSettings.GetStyleSettings();
- aStyleSettings.SetLabelTextColor(aColorAnchor);
- aSettings.SetStyleSettings(aStyleSettings);
- mpMetadataAuthor->SetSettings(aSettings);
- }
+ m_xContainer->set_background(mColorDark);
+ mxMenuButton->set_background(mColorDark);
- {
- mpMetadataDate->SetControlBackground(mColorDark);
- AllSettings aSettings = mpMetadataDate->GetSettings();
- StyleSettings aStyleSettings = aSettings.GetStyleSettings();
- aStyleSettings.SetLabelTextColor(aColorAnchor);
- aSettings.SetStyleSettings(aStyleSettings);
- mpMetadataDate->SetSettings(aSettings);
- }
+ mxMetadataAuthor->set_font_color(aColorAnchor);
- {
- mpMetadataResolved->SetControlBackground(mColorDark);
- AllSettings aSettings = mpMetadataResolved->GetSettings();
- StyleSettings aStyleSettings = aSettings.GetStyleSettings();
- aStyleSettings.SetLabelTextColor(aColorAnchor);
- aSettings.SetStyleSettings(aStyleSettings);
- mpMetadataResolved->SetSettings(aSettings);
- }
+ mxMetadataDate->set_font_color(aColorAnchor);
+
+ mxMetadataResolved->set_font_color(aColorAnchor);
- AllSettings aSettings2 = mpVScrollbar->GetSettings();
- StyleSettings aStyleSettings2 = aSettings2.GetStyleSettings();
- aStyleSettings2.SetButtonTextColor(Color(0,0,0));
- aStyleSettings2.SetCheckedColor(mColorLight); // background
- aStyleSettings2.SetShadowColor(mColorAnchor);
- aStyleSettings2.SetFaceColor(mColorDark);
- aSettings2.SetStyleSettings(aStyleSettings2);
- mpVScrollbar->SetSettings(aSettings2);
+ mxVScrollbar->customize_scrollbars(mColorLight,
+ mColorAnchor,
+ mColorDark,
+ GetPrefScrollbarWidth());
}
void SwAnnotationWin::SetSidebarPosition(sw::sidebarwindows::SidebarPosition eSidebarPosition)
@@ -1145,8 +894,8 @@ void SwAnnotationWin::SetLanguage(const SvxLanguageItem& rNewItem)
void SwAnnotationWin::GetFocus()
{
- if (mpSidebarTextControl)
- mpSidebarTextControl->GrabFocus();
+ if (mxSidebarTextControl)
+ mxSidebarTextControl->GrabFocus();
}
void SwAnnotationWin::LoseFocus()
@@ -1165,8 +914,6 @@ void SwAnnotationWin::ShowNote()
if (mpTextRangeOverlay && !mpTextRangeOverlay->isVisible())
mpTextRangeOverlay->setVisible(true);
- // Invalidate.
- InvalidateControl();
collectUIInformation("SHOW",get_id());
}
@@ -1188,15 +935,6 @@ void SwAnnotationWin::HideNote()
collectUIInformation("HIDE",get_id());
}
-void SwAnnotationWin::InvalidateControl()
-{
- // Invalidate.
- mpSidebarTextControl->Push(PushFlags::MAPMODE);
- lcl_translateTwips(EditWin(), *mpSidebarTextControl, nullptr);
- mpSidebarTextControl->Invalidate();
- mpSidebarTextControl->Pop();
-}
-
void SwAnnotationWin::ActivatePostIt()
{
mrMgr.AssureStdModeAtShell();
@@ -1353,45 +1091,27 @@ void SwAnnotationWin::SwitchToPostIt(sal_uInt16 aDirection)
pPostIt->GrabFocus();
}
-IMPL_LINK( SwAnnotationWin, WindowEventListener, VclWindowEvent&, rEvent, void )
+IMPL_LINK(SwAnnotationWin, MouseMoveHdl, const MouseEvent&, rMEvt, bool)
{
- if ( rEvent.GetId() == VclEventId::WindowMouseMove )
+ if (rMEvt.IsEnterWindow())
{
- MouseEvent* pMouseEvt = static_cast<MouseEvent*>(rEvent.GetData());
- if ( pMouseEvt->IsEnterWindow() )
- {
- mbMouseOver = true;
- if ( !HasFocus() )
- {
- SetViewState(ViewState::VIEW);
- Invalidate();
- }
- }
- else if ( pMouseEvt->IsLeaveWindow())
+ mbMouseOver = true;
+ if ( !HasFocus() )
{
- mbMouseOver = false;
- if ( !HasFocus() )
- {
- SetViewState(ViewState::NORMAL);
- Invalidate();
- }
+ SetViewState(ViewState::VIEW);
+ Invalidate();
}
}
- else if ( rEvent.GetId() == VclEventId::WindowActivate &&
- rEvent.GetWindow() == mpSidebarTextControl )
+ else if (rMEvt.IsLeaveWindow())
{
- SetActiveSidebarWin();
- /* We want this SwAnnotationWin to become visible on activation,
- but if we are activating because the mouse is pressed in the
- annotation and SidebarTextControl::MouseButtonDown is calling
- 'GrabFocus' then leave the MakeVisible to
- SidebarTextControl::MouseButtonUp instead. That way a mouse down
- doesn't scroll the writer window while the mouse is pressed, and so
- doesn't select random text as the editview is scrolled under the
- mouse */
- if (!mpSidebarTextControl->MouseDownGainingFocus())
- mrMgr.MakeVisible( this );
+ mbMouseOver = false;
+ if ( !HasFocus() )
+ {
+ SetViewState(ViewState::NORMAL);
+ Invalidate();
+ }
}
+ return false;
}
bool SwAnnotationWin::SetActiveSidebarWin()
@@ -1415,9 +1135,9 @@ void SwAnnotationWin::UnsetActiveSidebarWin()
mrView.GetWrtShell().LockView( bLockView );
}
-IMPL_LINK(SwAnnotationWin, ScrollHdl, ScrollBar*, pScroll, void)
+IMPL_LINK(SwAnnotationWin, ScrollHdl, weld::ScrolledWindow&, rScrolledWindow, void)
{
- tools::Long nDiff = GetOutlinerView()->GetEditView().GetVisArea().Top() - pScroll->GetThumbPos();
+ tools::Long nDiff = GetOutlinerView()->GetEditView().GetVisArea().Top() - rScrolledWindow.vadjustment_get_value();
GetOutlinerView()->Scroll( 0, nDiff );
}
@@ -1439,7 +1159,7 @@ void SwAnnotationWin::ResetAttributes()
mpOutlinerView->SetAttribs(DefaultItem());
}
-sal_Int32 SwAnnotationWin::GetScrollbarWidth() const
+int SwAnnotationWin::GetPrefScrollbarWidth() const
{
return mrView.GetWrtShell().GetViewOptions()->GetZoom() / 10;
}
@@ -1608,12 +1328,12 @@ void SwAnnotationWin::SetChangeTracking( const SwPostItHelper::SwLayoutStatus aL
bool SwAnnotationWin::HasScrollbar() const
{
- return mpVScrollbar != nullptr;
+ return static_cast<bool>(mxVScrollbar);
}
bool SwAnnotationWin::IsScrollbarVisible() const
{
- return HasScrollbar() && mpVScrollbar->IsVisible();
+ return HasScrollbar() && mxVScrollbar->get_vpolicy() == VclPolicyType::ALWAYS;
}
void SwAnnotationWin::ChangeSidebarItem( SwSidebarItem const & rSidebarItem )
@@ -1627,14 +1347,8 @@ void SwAnnotationWin::ChangeSidebarItem( SwSidebarItem const & rSidebarItem )
mrSidebarItem = rSidebarItem;
mpAnchorFrame = mrSidebarItem.maLayoutInfo.mpAnchorFrame;
- if ( GetWindowPeer() )
- {
- SidebarWinAccessible* pAcc =
- static_cast<SidebarWinAccessible*>( GetWindowPeer() );
- OSL_ENSURE( dynamic_cast<SidebarWinAccessible*>( GetWindowPeer() ),
- "<SwAnnotationWin::ChangeSidebarItem(..)> - unexpected type of window peer -> crash possible!" );
+ if (SidebarWinAccessible* pAcc = dynamic_cast<SidebarWinAccessible*>(GetWindowPeer()))
pAcc->ChangeSidebarItem( mrSidebarItem );
- }
if ( bAnchorChanged )
{
diff --git a/sw/source/uibase/docvw/PostItMgr.cxx b/sw/source/uibase/docvw/PostItMgr.cxx
index 84144c447bbb..d8b79c6e9d7e 100644
--- a/sw/source/uibase/docvw/PostItMgr.cxx
+++ b/sw/source/uibase/docvw/PostItMgr.cxx
@@ -827,10 +827,7 @@ void SwPostItMgr::LayoutPostIts()
comphelper::LibreOfficeKit::setTiledPainting(!visiblePostIt->HasChildPathFocus());
visiblePostIt->ShowNote();
if (!bTiledPainting)
- {
comphelper::LibreOfficeKit::setTiledPainting(bTiledPainting);
- visiblePostIt->InvalidateControl();
- }
}
else
{
@@ -965,7 +962,7 @@ void SwPostItMgr::DrawNotesForPage(OutputDevice *pOutDev, sal_uInt32 nPage)
if (!pPostIt)
continue;
Point aPoint(mpEditWin->PixelToLogic(pPostIt->GetPosPixel()));
- pPostIt->Draw(pOutDev, aPoint, DrawFlags::NONE);
+ pPostIt->DrawForPage(pOutDev, aPoint);
}
}
diff --git a/sw/source/uibase/docvw/SidebarScrollBar.cxx b/sw/source/uibase/docvw/SidebarScrollBar.cxx
deleted file mode 100644
index c7e2978afe4d..000000000000
--- a/sw/source/uibase/docvw/SidebarScrollBar.cxx
+++ /dev/null
@@ -1,73 +0,0 @@
-/* -*- 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/.
- */
-
-#include "SidebarScrollBar.hxx"
-
-#include <sfx2/lokhelper.hxx>
-
-#include <view.hxx>
-#include <wrtsh.hxx>
-#include <edtwin.hxx>
-#include <AnnotationWin.hxx>
-
-namespace sw::sidebarwindows
-{
-SidebarScrollBar::SidebarScrollBar(sw::annotation::SwAnnotationWin& rSidebarWin, WinBits nStyle,
- SwView& rView)
- : ScrollBar(&rSidebarWin, nStyle)
- , m_rSidebarWin(rSidebarWin)
- , m_rView(rView)
-{
-}
-
-void SidebarScrollBar::LogicInvalidate(const tools::Rectangle* pRectangle)
-{
- tools::Rectangle aRectangle;
-
- if (!pRectangle)
- {
- Push(PushFlags::MAPMODE);
- EnableMapMode();
- MapMode aMapMode = GetMapMode();
- aMapMode.SetMapUnit(MapUnit::MapTwip);
- SetMapMode(aMapMode);
- aRectangle = tools::Rectangle(Point(0, 0), PixelToLogic(GetSizePixel()));
- Pop();
- }
- else
- aRectangle = *pRectangle;
-
- // Convert from relative twips to absolute ones.
- vcl::Window& rParent = m_rSidebarWin.EditWin();
- Point aOffset(GetOutOffXPixel() - rParent.GetOutOffXPixel(),
- GetOutOffYPixel() - rParent.GetOutOffYPixel());
- rParent.Push(PushFlags::MAPMODE);
- rParent.EnableMapMode();
- aOffset = rParent.PixelToLogic(aOffset);
- rParent.Pop();
- aRectangle.Move(aOffset.getX(), aOffset.getY());
-
- OString sRectangle = aRectangle.toString();
- SwWrtShell& rWrtShell = m_rView.GetWrtShell();
- SfxLokHelper::notifyInvalidation(rWrtShell.GetSfxViewShell(), sRectangle);
-}
-
-void SidebarScrollBar::MouseButtonUp(const MouseEvent& /*rMouseEvent*/) { EndTracking(); }
-
-void SidebarScrollBar::MouseMove(const MouseEvent& rMouseEvent)
-{
- TrackingEvent aEvent(rMouseEvent);
- Tracking(aEvent);
-}
-
-SidebarScrollBar::~SidebarScrollBar() { disposeOnce(); }
-
-} // end of namespace sw::sidebarwindows
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sw/source/uibase/docvw/SidebarScrollBar.hxx b/sw/source/uibase/docvw/SidebarScrollBar.hxx
deleted file mode 100644
index 8d7ddd6c8486..000000000000
--- a/sw/source/uibase/docvw/SidebarScrollBar.hxx
+++ /dev/null
@@ -1,40 +0,0 @@
-/* -*- 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/.
- */
-
-#pragma once
-
-#include <vcl/scrbar.hxx>
-
-class SwView;
-namespace sw::annotation
-{
-class SwAnnotationWin;
-}
-
-namespace sw::sidebarwindows
-{
-/// Similar to the VCL scrollbar, but instrumented with Writer-specific details for LOK.
-class SidebarScrollBar : public ScrollBar
-{
- sw::annotation::SwAnnotationWin& m_rSidebarWin;
- SwView& m_rView;
-
-protected:
- /// @see Window::LogicInvalidate().
- void LogicInvalidate(const tools::Rectangle* pRectangle) override;
- void MouseMove(const MouseEvent& rMouseEvent) override;
- void MouseButtonUp(const MouseEvent& rMouseEvent) override;
-
-public:
- SidebarScrollBar(sw::annotation::SwAnnotationWin& rSidebarWin, WinBits nStyle, SwView& rView);
- ~SidebarScrollBar() override;
-};
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sw/source/uibase/docvw/SidebarTxtControl.cxx b/sw/source/uibase/docvw/SidebarTxtControl.cxx
index 390ed80b0712..ee8f83f6b85d 100644
--- a/sw/source/uibase/docvw/SidebarTxtControl.cxx
+++ b/sw/source/uibase/docvw/SidebarTxtControl.cxx
@@ -19,7 +19,6 @@
#include "SidebarTxtControl.hxx"
-#include "SidebarTxtControlAcc.hxx"
#include <docsh.hxx>
#include <doc.hxx>
@@ -59,42 +58,82 @@
namespace sw::sidebarwindows {
-SidebarTextControl::SidebarTextControl( sw::annotation::SwAnnotationWin& rSidebarWin,
- WinBits nBits,
- SwView& rDocView,
- SwPostItMgr& rPostItMgr )
- : Control( &rSidebarWin, nBits )
- , mrSidebarWin( rSidebarWin )
- , mrDocView( rDocView )
- , mrPostItMgr( rPostItMgr )
+SidebarTextControl::SidebarTextControl(sw::annotation::SwAnnotationWin& rSidebarWin,
+ SwView& rDocView,
+ SwPostItMgr& rPostItMgr)
+ : mrSidebarWin(rSidebarWin)
+ , mrDocView(rDocView)
+ , mrPostItMgr(rPostItMgr)
, mbMouseDownGainingFocus(false)
{
- AddEventListener( LINK( &mrSidebarWin, sw::annotation::SwAnnotationWin, WindowEventListener ) );
}
-SidebarTextControl::~SidebarTextControl()
+EditView* SidebarTextControl::GetEditView() const
{
- disposeOnce();
+ OutlinerView* pOutlinerView = mrSidebarWin.GetOutlinerView();
+ if (!pOutlinerView)
+ return nullptr;
+ return &pOutlinerView->GetEditView();
}
-void SidebarTextControl::dispose()
+EditEngine* SidebarTextControl::GetEditEngine() const
{
- RemoveEventListener( LINK( &mrSidebarWin, sw::annotation::SwAnnotationWin, WindowEventListener ) );
- Control::dispose();
+ OutlinerView* pOutlinerView = mrSidebarWin.GetOutlinerView();
+ if (!pOutlinerView)
+ return nullptr;
+ return pOutlinerView->GetEditView().GetEditEngine();
}
-OutlinerView* SidebarTextControl::GetTextView() const
+void SidebarTextControl::SetDrawingArea(weld::DrawingArea* pDrawingArea)
{
- return mrSidebarWin.GetOutlinerView();
+ Size aSize(0, 0);
+ pDrawingArea->set_size_request(aSize.Width(), aSize.Height());
+
+ SetOutputSizePixel(aSize);
+
+ weld::CustomWidgetController::SetDrawingArea(pDrawingArea);
+
+ EnableRTL(false);
+
+ const StyleSettings& rStyleSettings = Application::GetSettings().GetStyleSettings();
+ Color aBgColor = rStyleSettings.GetWindowColor();
+
+ OutputDevice& rDevice = pDrawingArea->get_ref_device();
+
+ rDevice.SetMapMode(MapMode(MapUnit::MapTwip));
+ rDevice.SetBackground(aBgColor);
+
+ Size aOutputSize(rDevice.PixelToLogic(aSize));
+ aSize = aOutputSize;
+ aSize.setHeight(aSize.Height());
+
+ EditView* pEditView = GetEditView();
+ pEditView->setEditViewCallbacks(this);
+
+ EditEngine* pEditEngine = GetEditEngine();
+ pEditEngine->SetPaperSize(aSize);
+ pEditEngine->SetRefDevice(&rDevice);
+
+ pEditView->SetOutputArea(tools::Rectangle(Point(0, 0), aOutputSize));
+ pEditView->SetBackgroundColor(aBgColor);
+
+ pDrawingArea->set_cursor(PointerStyle::Text);
+
+ InitAccessible();
+}
+
+void SidebarTextControl::SetCursorLogicPosition(const Point& rPosition, bool bPoint, bool bClearMark)
+{
+ Point aMousePos = EditViewOutputDevice().PixelToLogic(rPosition);
+ m_xEditView->SetCursorLogicPosition(aMousePos, bPoint, bClearMark);
}
void SidebarTextControl::GetFocus()
{
- Window::GetFocus();
+ WeldEditView::GetFocus();
if ( !mrSidebarWin.IsMouseOver() )
- {
Invalidate();
- }
+ mrSidebarWin.SetActiveSidebarWin();
}
void SidebarTextControl::LoseFocus()
@@ -102,15 +141,34 @@ void SidebarTextControl::LoseFocus()
// write the visible text back into the SwField
mrSidebarWin.UpdateData();
- Window::LoseFocus();
+ WeldEditView::LoseFocus();
if ( !mrSidebarWin.IsMouseOver() )
{
Invalidate();
}
}
-void SidebarTextControl::RequestHelp(const HelpEvent &rEvt)
+OUString SidebarTextControl::RequestHelp(tools::Rectangle& rHelpRect)
{
+ if (EditView* pEditView = GetEditView())
+ {
+ Point aPos = rHelpRect.TopLeft();
+
+ const OutputDevice& rOutDev = pEditView->GetOutputDevice();
+ Point aLogicClick = rOutDev.PixelToLogic(aPos);
+ const SvxFieldItem* pItem = pEditView->GetField(aLogicClick);
+ if (pItem)
+ {
+ const SvxFieldData* pField = pItem->GetField();
+ const SvxURLField* pURL = dynamic_cast<const SvxURLField*>( pField );
+ if (pURL)
+ {
+ rHelpRect = tools::Rectangle(aPos, Size(50, 10));
+ return SfxHelp::GetURLHelpText(pURL->GetURL());
+ }
+ }
+ }
+
const char* pResId = nullptr;
switch( mrSidebarWin.GetLayoutStatus() )
{
@@ -126,18 +184,26 @@ void SidebarTextControl::RequestHelp(const HelpEvent &rEvt)
OUString sText = SwResId(pResId) + ": " +
aContentAtPos.aFnd.pRedl->GetAuthorString() + " - " +
GetAppLangDateTimeString( aContentAtPos.aFnd.pRedl->GetTimeStamp() );
- Help::ShowQuickHelp( this,PixelToLogic(tools::Rectangle(rEvt.GetMousePosPixel(),Size(50,10))),sText);
+ return sText;
}
+
+ return OUString();
}
-void SidebarTextControl::Draw(OutputDevice* pDev, const Point& rPt, DrawFlags)
+void SidebarTextControl::EditViewScrollStateChange()
+{
+ mrSidebarWin.SetScrollbar();
+}
+
+void SidebarTextControl::DrawForPage(OutputDevice* pDev, const Point& rPt)
{
//Take the control's height, but overwrite the scrollbar area if there was one
- Size aSize(PixelToLogic(GetSizePixel()));
+ OutputDevice& rDevice = GetDrawingArea()->get_ref_device();
+ Size aSize(rDevice.PixelToLogic(GetOutputSizePixel()));
- if ( GetTextView() )
+ if (OutlinerView* pOutlinerView = mrSidebarWin.GetOutlinerView())
{
- GetTextView()->GetOutliner()->Draw(pDev, tools::Rectangle(rPt, aSize));
+ pOutlinerView->GetOutliner()->Draw(pDev, tools::Rectangle(rPt, aSize));
}
if ( mrSidebarWin.GetLayoutStatus()==SwPostItHelper::DELETED )
@@ -163,93 +229,64 @@ void SidebarTextControl::Draw(OutputDevice* pDev, const Point& rPt, DrawFlags)
void SidebarTextControl::Paint(vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect)
{
+ Size aSize = GetOutputSizePixel();
+ Point aPos;
+
if (!rRenderContext.GetSettings().GetStyleSettings().GetHighContrastMode())
{
if (mrSidebarWin.IsMouseOverSidebarWin() || HasFocus())
{
- rRenderContext.DrawGradient(tools::Rectangle(Point(0,0), rRenderContext.PixelToLogic(GetSizePixel())),
+ rRenderContext.DrawGradient(tools::Rectangle(aPos, rRenderContext.PixelToLogic(aSize)),
Gradient(GradientStyle::Linear, mrSidebarWin.ColorDark(), mrSidebarWin.ColorDark()));
}
else
{
- rRenderContext.DrawGradient(tools::Rectangle(Point(0,0), rRenderContext.PixelToLogic(GetSizePixel())),
+ rRenderContext.DrawGradient(tools::Rectangle(aPos, rRenderContext.PixelToLogic(aSize)),
Gradient(GradientStyle::Linear, mrSidebarWin.ColorLight(), mrSidebarWin.ColorDark()));
}
}
- if (GetTextView())
- {
- GetTextView()->Paint(rRect, &rRenderContext);
- }
+ DoPaint(rRenderContext, rRect);
if (mrSidebarWin.GetLayoutStatus() == SwPostItHelper::DELETED)
{
rRenderContext.SetLineColor(mrSidebarWin.GetChangeColor());
- rRenderContext.DrawLine(rRenderContext.PixelToLogic(GetPosPixel()),
- rRenderContext.PixelToLogic(GetPosPixel() + Point(GetSizePixel().Width(),
- GetSizePixel().Height())));
- rRenderContext.DrawLine(rRenderContext.PixelToLogic(GetPosPixel() + Point(GetSizePixel().Width(),
- 0)),
- rRenderContext.PixelToLogic(GetPosPixel() + Point(0,
- GetSizePixel().Height())));
- }
-}
-
-void SidebarTextControl::LogicInvalidate(const tools::Rectangle* pRectangle)
-{
- tools::Rectangle aRectangle;
-
- if (!pRectangle)
- {
- Push(PushFlags::MAPMODE);
- EnableMapMode();
- aRectangle = tools::Rectangle(Point(0, 0), PixelToLogic(GetSizePixel()));
- Pop();
+ rRenderContext.DrawLine(rRenderContext.PixelToLogic(aPos),
+ rRenderContext.PixelToLogic(aPos + Point(aSize.Width(),
+ aSize.Height())));
+ rRenderContext.DrawLine(rRenderContext.PixelToLogic(aPos + Point(aSize.Width(),
+ 0)),
+ rRenderContext.PixelToLogic(aPos + Point(0,
+ aSize.Height())));
}
- else
- aRectangle = *pRectangle;
-
- // Convert from relative twips to absolute ones.
- vcl::Window& rParent = mrSidebarWin.EditWin();
- Point aOffset(GetOutOffXPixel() - rParent.GetOutOffXPixel(), GetOutOffYPixel() - rParent.GetOutOffYPixel());
- rParent.Push(PushFlags::MAPMODE);
- rParent.EnableMapMode();
- aOffset = rParent.PixelToLogic(aOffset);
- rParent.Pop();
- aRectangle.Move(aOffset.getX(), aOffset.getY());
-
- OString sRectangle = aRectangle.toString();
- SwWrtShell& rWrtShell = mrDocView.GetWrtShell();
- SfxLokHelper::notifyInvalidation(rWrtShell.GetSfxViewShell(), sRectangle);
}
void SidebarTextControl::MakeVisible()
{
- // PostItMgr::MakeVisible can lose our MapMode, save it.
- auto oldMapMode = GetMapMode();
//let's make sure we see our note
mrPostItMgr.MakeVisible(&mrSidebarWin);
- if (comphelper::LibreOfficeKit::isActive())
- SetMapMode(oldMapMode);
}
-void SidebarTextControl::KeyInput( const KeyEvent& rKeyEvt )
+bool SidebarTextControl::KeyInput( const KeyEvent& rKeyEvt )
{
if (getenv("SW_DEBUG") && rKeyEvt.GetKeyCode().GetCode() == KEY_F12)
{
if (rKeyEvt.GetKeyCode().IsShift())
{
mrDocView.GetDocShell()->GetDoc()->dumpAsXml();
- return;
+ return true;
}
}
+ bool bDone = false;
+
const vcl::KeyCode& rKeyCode = rKeyEvt.GetKeyCode();
sal_uInt16 nKey = rKeyCode.GetCode();
if ( ( rKeyCode.IsMod1() && rKeyCode.IsMod2() ) &&
( (nKey == KEY_PAGEUP) || (nKey == KEY_PAGEDOWN) ) )
{
mrSidebarWin.SwitchToPostIt(nKey);
+ bDone = true;
}
else if ( nKey == KEY_ESCAPE ||
( rKeyCode.IsMod1() &&
@@ -257,17 +294,18 @@ void SidebarTextControl::KeyInput( const KeyEvent& rKeyEvt )
nKey == KEY_PAGEDOWN ) ) )
{
mrSidebarWin.SwitchToFieldPos();
+ bDone = true;
}
else if ( rKeyCode.GetFullCode() == KEY_INSERT )
{
mrSidebarWin.ToggleInsMode();
+ bDone = true;
}
else
{
MakeVisible();
tools::Long aOldHeight = mrSidebarWin.GetPostItTextHeight();
- bool bDone = false;
/// HACK: need to switch off processing of Undo/Redo in Outliner
if ( !( (nKey == KEY_Z || nKey == KEY_Y) && rKeyCode.IsMod1()) )
@@ -275,11 +313,12 @@ void SidebarTextControl::KeyInput( const KeyEvent& rKeyEvt )
bool bIsProtected = mrSidebarWin.IsProtected();
if ( !bIsProtected || !EditEngine::DoesKeyChangeText(rKeyEvt) )
{
- bDone = GetTextView() && GetTextView()->PostKeyEvent( rKeyEvt );
+ EditView* pEditView = GetEditView();
+ bDone = pEditView && pEditView->PostKeyEvent(rKeyEvt);
}
else
{
- std::unique_ptr<weld::Builder> xBuilder(Application::CreateBuilder(GetFrameWeld(), "modules/swriter/ui/inforeadonlydialog.ui"));
+ std::unique_ptr<weld::Builder> xBuilder(Application::CreateBuilder(GetDrawingArea(), "modules/swriter/ui/inforeadonlydialog.ui"));
std::unique_ptr<weld::MessageDialog> xQuery(xBuilder->weld_message_dialog("InfoReadonlyDialog"));
xQuery->run();
}
@@ -291,63 +330,38 @@ void SidebarTextControl::KeyInput( const KeyEvent& rKeyEvt )
// write back data first when showing navigator
if ( nKey==KEY_F5 )
mrSidebarWin.UpdateData();
- if (!mrDocView.KeyInput(rKeyEvt))
- Window::KeyInput(rKeyEvt);
+ bDone = mrDocView.KeyInput(rKeyEvt);
}
}
mrDocView.GetViewFrame()->GetBindings().InvalidateAll(false);
-}
-void SidebarTextControl::MouseMove( const MouseEvent& rMEvt )
-{
- if ( !GetTextView() )
- return;
-
- OutlinerView* pOutlinerView( GetTextView() );
- pOutlinerView->MouseMove( rMEvt );
- // mba: why does OutlinerView not handle the modifier setting?!
- // this forces the postit to handle *all* pointer types
- SetPointer( pOutlinerView->GetPointer( rMEvt.GetPosPixel() ) );
-
- const EditView& aEV = pOutlinerView->GetEditView();
- const SvxFieldItem* pItem = aEV.GetFieldUnderMousePointer();
- if ( pItem )
- {
- const SvxFieldData* pField = pItem->GetField();
- const SvxURLField* pURL = dynamic_cast<const SvxURLField*>( pField );
- if ( pURL )
- {
- OUString sText(SfxHelp::GetURLHelpText(pURL->GetURL()));
- Help::ShowQuickHelp(
- this, PixelToLogic(tools::Rectangle(GetPosPixel(), Size(50, 10))), sText);
- }
- }
+ return bDone;
}
-void SidebarTextControl::MouseButtonDown( const MouseEvent& rMEvt )
+bool SidebarTextControl::MouseButtonDown(const MouseEvent& rMEvt)
{
- if ( GetTextView() )
+ if (EditView* pEditView = GetEditView())
{
SvtSecurityOptions aSecOpts;
bool bExecuteMod = aSecOpts.IsOptionSet( SvtSecurityOptions::EOption::CtrlClickHyperlink);
if ( !bExecuteMod || (rMEvt.GetModifier() == KEY_MOD1))
{
- const EditView& aEV = GetTextView()->GetEditView();
- const SvxFieldItem* pItem = aEV.GetFieldUnderMousePointer();
- if ( pItem )
+ const OutputDevice& rOutDev = pEditView->GetOutputDevice();
+ Point aLogicClick = rOutDev.PixelToLogic(rMEvt.GetPosPixel());
+ if (const SvxFieldItem* pItem = pEditView->GetField(aLogicClick))
{
const SvxFieldData* pField = pItem->GetField();
const SvxURLField* pURL = dynamic_cast<const SvxURLField*>( pField );
if ( pURL )
{
- GetTextView()->MouseButtonDown( rMEvt );
+ pEditView->MouseButtonDown( rMEvt );
SwWrtShell &rSh = mrDocView.GetWrtShell();
const OUString& sURL( pURL->GetURL() );
const OUString& sTarget( pURL->GetTargetFrame() );
::LoadURL(rSh, sURL, LoadUrlFlags::NONE, sTarget);
- return;
+ return true;
}
}
}
@@ -356,22 +370,24 @@ void SidebarTextControl::MouseButtonDown( const MouseEvent& rMEvt )
mbMouseDownGainingFocus = !HasFocus();
GrabFocus();
- if ( GetTextView() )
- {
- GetTextView()->MouseButtonDown( rMEvt );
- }
+ bool bRet = WeldEditView::MouseButtonDown(rMEvt);
+
mrDocView.GetViewFrame()->GetBindings().InvalidateAll(false);
+
+ return bRet;
}
-void SidebarTextControl::MouseButtonUp( const MouseEvent& rMEvt )
+bool SidebarTextControl::MouseButtonUp(const MouseEvent& rMEvt)
{
- if ( GetTextView() )
- GetTextView()->MouseButtonUp( rMEvt );
+ bool bRet = WeldEditView::MouseButtonUp(rMEvt);
+
if (mbMouseDownGainingFocus)
{
MakeVisible();
mbMouseDownGainingFocus = false;
}
+
+ return bRet;
}
IMPL_LINK( SidebarTextControl, OnlineSpellCallback, SpellCallbackInfo&, rInfo, void )
@@ -382,16 +398,18 @@ IMPL_LINK( SidebarTextControl, OnlineSpellCallback, SpellCallbackInfo&, rInfo, v
}
}
-void SidebarTextControl::Command( const CommandEvent& rCEvt )
+bool SidebarTextControl::Command( const CommandEvent& rCEvt )
{
+ EditView* pEditView = GetEditView();
+
if ( rCEvt.GetCommand() == CommandEventId::ContextMenu )
{
if ( !mrSidebarWin.IsProtected() &&
- GetTextView() &&
- GetTextView()->IsWrongSpelledWordAtPos( rCEvt.GetMousePosPixel(), true ))
+ pEditView &&
+ pEditView->IsWrongSpelledWordAtPos( rCEvt.GetMousePosPixel(), true ))
{
Link<SpellCallbackInfo&,void> aLink = LINK(this, SidebarTextControl, OnlineSpellCallback);
- GetTextView()->ExecuteSpellPopup(rCEvt.GetMousePosPixel(),&aLink);
+ pEditView->ExecuteSpellPopup(rCEvt.GetMousePosPixel(),&aLink);
}
else
{
@@ -400,71 +418,35 @@ void SidebarTextControl::Command( const CommandEvent& rCEvt )
aPos = rCEvt.GetMousePosPixel();
else
{
- const Size aSize = GetSizePixel();
+ const Size aSize = GetOutputSizePixel();
aPos = Point( aSize.getWidth()/2, aSize.getHeight()/2 );
}
- SfxDispatcher::ExecutePopup(this, &aPos);
+ SfxDispatcher::ExecutePopup(&mrSidebarWin, &aPos);
}
+ return true;
}
- else
- if (rCEvt.GetCommand() == CommandEventId::Wheel)
+ else if (rCEvt.GetCommand() == CommandEventId::Wheel)
{
- if (mrSidebarWin.IsScrollbarVisible())
+ // if no scrollbar, or extra keys held scroll the document and consume
+ // this event, otherwise don't consume and let the event get to the
+ // surrounding scrolled window
+ if (!mrSidebarWin.IsScrollbarVisible())
+ {
+ mrDocView.HandleWheelCommands(rCEvt);
+ return true;
+ }
+ else
{
const CommandWheelData* pData = rCEvt.GetWheelData();
if (pData->IsShift() || pData->IsMod1() || pData->IsMod2())
{
mrDocView.HandleWheelCommands(rCEvt);
+ return true;
}
- else
- {
- HandleScrollCommand( rCEvt, nullptr , mrSidebarWin.Scrollbar());
- }
- }
- else
- {
- mrDocView.HandleWheelCommands(rCEvt);
}
}
- else
- {
- if ( GetTextView() )
- GetTextView()->Command( rCEvt );
- else
- Window::Command(rCEvt);
- }
-}
-
-OUString SidebarTextControl::GetSurroundingText() const
-{
- if (OutlinerView* pTextView = GetTextView())
- return pTextView->GetSurroundingText();
- return OUString();
-}
-
-Selection SidebarTextControl::GetSurroundingTextSelection() const
-{
- if (OutlinerView* pTextView = GetTextView())
- return pTextView->GetSurroundingTextSelection();
- return Selection( 0, 0 );
-}
-
-bool SidebarTextControl::DeleteSurroundingText(const Selection& rSelection)
-{
- if (OutlinerView* pTextView = GetTextView())
- return pTextView->DeleteSurroundingText(rSelection);
- return false;
-}
-
-css::uno::Reference< css::accessibility::XAccessible > SidebarTextControl::CreateAccessible()
-{
-
- SidebarTextControlAccessible* pAcc( new SidebarTextControlAccessible( *this ) );
- css::uno::Reference< css::awt::XWindowPeer > xWinPeer( pAcc );
- SetWindowPeer( xWinPeer, pAcc );
- css::uno::Reference< css::accessibility::XAccessible > xAcc( xWinPeer, css::uno::UNO_QUERY );
- return xAcc;
+ return WeldEditView::Command(rCEvt);
}
} // end of namespace sw::sidebarwindows
diff --git a/sw/source/uibase/docvw/SidebarTxtControl.hxx b/sw/source/uibase/docvw/SidebarTxtControl.hxx
index 3460ba660ecd..596be78244a2 100644
--- a/sw/source/uibase/docvw/SidebarTxtControl.hxx
+++ b/sw/source/uibase/docvw/SidebarTxtControl.hxx
@@ -19,7 +19,7 @@
#pragma once
-#include <vcl/ctrl.hxx>
+#include <svx/weldeditview.hxx>
class OutlinerView;
class SwView;
@@ -29,7 +29,7 @@ namespace sw::annotation { class SwAnnotationWin; }
namespace sw::sidebarwindows {
-class SidebarTextControl : public Control
+class SidebarTextControl : public WeldEditView
{
private:
sw::annotation::SwAnnotationWin& mrSidebarWin;
@@ -40,39 +40,38 @@ class SidebarTextControl : public Control
void MakeVisible();
protected:
- virtual void Paint( vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect) override;
- /// @see Window::LogicInvalidate().
- void LogicInvalidate(const tools::Rectangle* pRectangle) override;
- virtual void Command( const CommandEvent& rCEvt ) override;
- virtual void LoseFocus() override;
- virtual void RequestHelp(const HelpEvent &rEvt) override;
- virtual OUString GetSurroundingText() const override;
- virtual Selection GetSurroundingTextSelection() const override;
- virtual bool DeleteSurroundingText(const Selection& rSelection) override;
+ virtual void Paint(vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect) override;
+
+ virtual bool Command(const CommandEvent& rCEvt) override;
+ virtual void GetFocus() override;
+ virtual void LoseFocus() override;
+
+ virtual OUString RequestHelp(tools::Rectangle& rRect) override;
public:
- SidebarTextControl( sw::annotation::SwAnnotationWin& rSidebarWin,
- WinBits nBits,
+ SidebarTextControl(sw::annotation::SwAnnotationWin& rSidebarWin,
SwView& rDocView,
- SwPostItMgr& rPostItMgr );
- virtual ~SidebarTextControl() override;
- virtual void dispose() override;
+ SwPostItMgr& rPostItMgr);
- virtual void GetFocus() override;
- virtual void KeyInput( const KeyEvent& rKeyEvt ) override;
- virtual void MouseButtonDown(const MouseEvent& rMouseEvent) override;
- virtual void MouseButtonUp(const MouseEvent& rMEvt) override;
- virtual void MouseMove(const MouseEvent& rMEvt) override;
+ virtual EditView* GetEditView() const override;
+
+ virtual EditEngine* GetEditEngine() const override;
- bool MouseDownGainingFocus() const { return mbMouseDownGainingFocus; }
+ virtual void EditViewScrollStateChange() override;
+
+ void SetDrawingArea(weld::DrawingArea* pDrawingArea) override;
+
+ void SetCursorLogicPosition(const Point& rPosition, bool bPoint, bool bClearMark);
+
+ virtual bool KeyInput(const KeyEvent& rKeyEvt) override;
+ virtual bool MouseButtonDown(const MouseEvent& rMEvt) override;
+ virtual bool MouseButtonUp(const MouseEvent& rMEvt) override;
OutlinerView* GetTextView() const;
DECL_LINK( OnlineSpellCallback, SpellCallbackInfo&, void );
- virtual css::uno::Reference< css::accessibility::XAccessible > CreateAccessible() override;
-
- virtual void Draw(OutputDevice* pDev, const Point&, DrawFlags) override;
+ void DrawForPage(OutputDevice* pDev, const Point& rPos);
};
} // end of namespace sw::sidebarwindows
diff --git a/sw/source/uibase/docvw/SidebarTxtControlAcc.cxx b/sw/source/uibase/docvw/SidebarTxtControlAcc.cxx
deleted file mode 100644
index d3bec6ecae5b..000000000000
--- a/sw/source/uibase/docvw/SidebarTxtControlAcc.cxx
+++ /dev/null
@@ -1,271 +0,0 @@
-/* -*- 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 <sal/config.h>
-
-#include <memory>
-
-#include "SidebarTxtControlAcc.hxx"
-
-#include "SidebarTxtControl.hxx"
-
-#include <svl/SfxBroadcaster.hxx>
-#include <toolkit/awt/vclxaccessiblecomponent.hxx>
-#include <editeng/unoedsrc.hxx>
-#include <editeng/unoforou.hxx>
-#include <editeng/unoviwou.hxx>
-#include <editeng/unoedhlp.hxx>
-#include <svx/AccessibleTextHelper.hxx>
-#include <editeng/outliner.hxx>
-#include <vcl/vclevent.hxx>
-
-namespace sw::sidebarwindows {
-
-namespace {
-
-// declaration and implementation of <SvxEditSource>
-// for <::accessibility::AccessibleTextHelper> instance
-class SidebarTextEditSource : public SvxEditSource,
- public SfxBroadcaster
-{
- public:
- explicit SidebarTextEditSource(SidebarTextControl& rSidebarTextControl);
- virtual ~SidebarTextEditSource() override;
-
- virtual std::unique_ptr<SvxEditSource> Clone() const override;
-
- virtual SvxTextForwarder* GetTextForwarder() override;
- virtual SvxViewForwarder* GetViewForwarder() override;
- virtual SvxEditViewForwarder* GetEditViewForwarder( bool bCreate = false ) override;
-
- virtual void UpdateData() override;
-
- virtual SfxBroadcaster& GetBroadcaster() const override;
- DECL_LINK( NotifyHdl, EENotify&, void );
-
- private:
- SidebarTextControl& mrSidebarTextControl;
- SvxOutlinerForwarder mTextForwarder;
- SvxDrawOutlinerViewForwarder mViewForwarder;
-};
-
-}
-
-SidebarTextEditSource::SidebarTextEditSource( SidebarTextControl& rSidebarTextControl )
- : SvxEditSource()
- , mrSidebarTextControl( rSidebarTextControl )
- , mTextForwarder( *(rSidebarTextControl.GetTextView()->GetOutliner()), false )
- , mViewForwarder( *(rSidebarTextControl.GetTextView()) )
-{
- if ( mrSidebarTextControl.GetTextView() )
- {
- mrSidebarTextControl.GetTextView()->GetOutliner()->SetNotifyHdl( LINK(this, SidebarTextEditSource, NotifyHdl) );
- }
-}
-
-SidebarTextEditSource::~SidebarTextEditSource()
-{
- if ( mrSidebarTextControl.GetTextView() )
- {
- mrSidebarTextControl.GetTextView()->GetOutliner()->SetNotifyHdl( Link<EENotify&,void>() );
- }
-}
-
-std::unique_ptr<SvxEditSource> SidebarTextEditSource::Clone() const
-{
- return std::unique_ptr<SvxEditSource>(new SidebarTextEditSource( mrSidebarTextControl ));
-}
-
-SvxTextForwarder* SidebarTextEditSource::GetTextForwarder()
-{
- return &mTextForwarder;
-}
-
-SvxViewForwarder* SidebarTextEditSource::GetViewForwarder()
-{
- return &mViewForwarder;
-}
-
-SvxEditViewForwarder* SidebarTextEditSource::GetEditViewForwarder( bool /*bCreate*/ )
-{
- return &mViewForwarder;
-}
-
-void SidebarTextEditSource::UpdateData()
-{
- // nothing to do
-}
-
-SfxBroadcaster& SidebarTextEditSource::GetBroadcaster() const
-{
- return * const_cast< SidebarTextEditSource* > (this);
-}
-
-IMPL_LINK(SidebarTextEditSource, NotifyHdl, EENotify&, rNotify, void)
-{
- std::unique_ptr< SfxHint > aHint( SvxEditSourceHelper::EENotification2Hint( &rNotify ) );
-
- if (aHint)
- {
- Broadcast(*aHint);
- }
-}
-
-namespace {
-
-// declaration and implementation of accessible context for <SidebarTextControl> instance
-class SidebarTextControlAccessibleContext : public VCLXAccessibleComponent
-{
- public:
- explicit SidebarTextControlAccessibleContext( SidebarTextControl& rSidebarTextControl );
-
- virtual sal_Int32 SAL_CALL
- getAccessibleChildCount() override;
- virtual css::uno::Reference< css::accessibility::XAccessible > SAL_CALL
- getAccessibleChild( sal_Int32 i ) override;
-
- virtual void SAL_CALL
- addAccessibleEventListener (
- const css::uno::Reference< css::accessibility::XAccessibleEventListener >& xListener) override;
- virtual void SAL_CALL
- removeAccessibleEventListener (
- const css::uno::Reference< css::accessibility::XAccessibleEventListener >& xListener) override;
-
- protected:
- virtual void ProcessWindowEvent( const VclWindowEvent& rVclWindowEvent ) override;
-
- private:
- std::unique_ptr<::accessibility::AccessibleTextHelper> mpAccessibleTextHelper;
-
- ::osl::Mutex maMutex;
-};
-
-}
-
-SidebarTextControlAccessibleContext::SidebarTextControlAccessibleContext( SidebarTextControl& rSidebarTextControl )
- : VCLXAccessibleComponent( rSidebarTextControl.GetWindowPeer() )
- , maMutex()
-{
- mpAccessibleTextHelper.reset(new ::accessibility::AccessibleTextHelper( std::make_unique<SidebarTextEditSource>(rSidebarTextControl) ));
- mpAccessibleTextHelper->SetEventSource( rSidebarTextControl.GetWindowPeer() );
-}
-
-sal_Int32 SAL_CALL SidebarTextControlAccessibleContext::getAccessibleChildCount()
-{
- osl::MutexGuard aGuard( maMutex );
-
- sal_Int32 nChildCount( 0 );
-
- if ( mpAccessibleTextHelper )
- {
- nChildCount = mpAccessibleTextHelper->GetChildCount();
- }
-
- return nChildCount;
-}
-
-css::uno::Reference< css::accessibility::XAccessible > SAL_CALL SidebarTextControlAccessibleContext::getAccessibleChild( sal_Int32 i )
-{
- osl::MutexGuard aGuard( maMutex );
-
- css::uno::Reference< css::accessibility::XAccessible > xChild;
-
- if ( mpAccessibleTextHelper )
- {
- xChild = mpAccessibleTextHelper->GetChild( i );
- }
-
- return xChild;
-}
-
-void SAL_CALL SidebarTextControlAccessibleContext::addAccessibleEventListener (
- const css::uno::Reference< css::accessibility::XAccessibleEventListener >& xListener)
-{
- osl::MutexGuard aGuard( maMutex );
-
- if ( mpAccessibleTextHelper )
- {
- mpAccessibleTextHelper->AddEventListener(xListener);
- }
-}
-
-void SAL_CALL SidebarTextControlAccessibleContext::removeAccessibleEventListener (
- const css::uno::Reference< css::accessibility::XAccessibleEventListener >& xListener)
-{
- osl::MutexGuard aGuard( maMutex );
-
- if ( mpAccessibleTextHelper )
- {
- mpAccessibleTextHelper->RemoveEventListener(xListener);
- }
-}
-
-void SidebarTextControlAccessibleContext::ProcessWindowEvent( const VclWindowEvent& rVclWindowEvent )
-{
- if ( mpAccessibleTextHelper )
- {
- switch ( rVclWindowEvent.GetId() )
- {
- case VclEventId::ObjectDying:
- {
- mpAccessibleTextHelper.reset();
- }
- break;
- case VclEventId::WindowGetFocus:
- case VclEventId::ControlGetFocus:
- {
- mpAccessibleTextHelper->SetFocus();
- }
- break;
- case VclEventId::WindowLoseFocus:
- case VclEventId::ControlLoseFocus:
- {
- mpAccessibleTextHelper->SetFocus( false );
- }
- break;
- default: break;
- }
- }
-
- VCLXAccessibleComponent::ProcessWindowEvent( rVclWindowEvent );
-}
-
-// implementation of accessible for <SidebarTextControl> instance
-SidebarTextControlAccessible::SidebarTextControlAccessible( SidebarTextControl& rSidebarTextControl )
- : VCLXWindow()
- , mrSidebarTextControl( rSidebarTextControl )
-{
- SetWindow( &mrSidebarTextControl );
-}
-
-SidebarTextControlAccessible::~SidebarTextControlAccessible()
-{
-}
-
-css::uno::Reference< css::accessibility::XAccessibleContext > SidebarTextControlAccessible::CreateAccessibleContext()
-{
- SidebarTextControlAccessibleContext* pAccContext(
- new SidebarTextControlAccessibleContext( mrSidebarTextControl ) );
- css::uno::Reference< css::accessibility::XAccessibleContext > xAcc( pAccContext );
- return xAcc;
-}
-
-} // end of namespace sw::sidebarwindows
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sw/source/uibase/docvw/SidebarTxtControlAcc.hxx b/sw/source/uibase/docvw/SidebarTxtControlAcc.hxx
deleted file mode 100644
index db60972501c6..000000000000
--- a/sw/source/uibase/docvw/SidebarTxtControlAcc.hxx
+++ /dev/null
@@ -1,43 +0,0 @@
-/* -*- 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 .
- */
-
-#pragma once
-
-#include <toolkit/awt/vclxwindow.hxx>
-
-namespace sw::sidebarwindows {
-
-class SidebarTextControl;
-
-class SidebarTextControlAccessible : public VCLXWindow
-{
- public:
- explicit SidebarTextControlAccessible( SidebarTextControl& rSidebarTextControl );
- virtual ~SidebarTextControlAccessible() override;
-
- virtual css::uno::Reference< css::accessibility::XAccessibleContext >
- CreateAccessibleContext() override;
-
- private:
- SidebarTextControl& mrSidebarTextControl;
-};
-
-} // end of namespace sw::sidebarwindows
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */