sw/source/uibase/utlui/content.cxx |   26 +++++++++++++++++---------
 1 file changed, 17 insertions(+), 9 deletions(-)

New commits:
commit b7f999e75f436bb0b162e16c96b54bbaa4b0101b
Author:     Jim Raykowski <rayk...@gmail..com>
AuthorDate: Tue Feb 18 01:20:11 2020 -0900
Commit:     Noel Grandin <noel.gran...@collabora.co.uk>
CommitDate: Wed Feb 19 07:24:41 2020 +0100

    Keep focus in Writer Navigator after content delete
    
    When deletable content in Writer Navigator is deleted by pressing the
    delete key, focus remains in the content tree. When the delete menu item
    is used, focus changes to the document window. This patch changes focus
    behaviour of menu item use to that of key press. It keeps focus in
    Writer Navigator after content delete is done from the Writer
    Navigator.
    
    Change-Id: Ie96e3c55f0cd95c6955e65f9de5d38ddd134d30e
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/87171
    Tested-by: Jenkins
    Reviewed-by: Noel Grandin <noel.gran...@collabora.co.uk>

diff --git a/sw/source/uibase/utlui/content.cxx 
b/sw/source/uibase/utlui/content.cxx
index 52b863602d8e..660cf16be92b 100644
--- a/sw/source/uibase/utlui/content.cxx
+++ b/sw/source/uibase/utlui/content.cxx
@@ -3051,14 +3051,7 @@ void SwContentTree::KeyInput(const KeyEvent& rEvent)
             if 
(static_cast<SwContent*>(pEntry->GetUserData())->GetParent()->IsDeletable() &&
                     !m_pActiveShell->GetView().GetDocShell()->IsReadOnly())
             {
-                if 
(static_cast<SwContent*>(pEntry->GetUserData())->GetParent()->GetType() == 
ContentTypeId::OUTLINE)
-                    DeleteOutlineSelections();
-                else
-                    EditEntry(pEntry, EditEntryMode::DELETE);
-                m_bViewHasChanged = true;
-                GetParentWindow()->UpdateListBox();
-                TimerUpdate(&m_aUpdTimer);
-                GrabFocus();
+                EditEntry(pEntry, EditEntryMode::DELETE);
             }
         }
     }
@@ -3394,7 +3387,8 @@ void SwContentTree::ExecuteContextMenuAction( sal_uInt16 
nSelectedPopupEntry )
         }
         break;
         case 806:
-            DeleteOutlineSelections();
+            // Delete outline selections
+            EditEntry(pFirst, EditEntryMode::DELETE);
             break;
         //Display
         default:
@@ -3548,6 +3542,13 @@ void SwContentTree::EditEntry(SvTreeListEntry const * 
pEntry, EditEntryMode nMod
     uno::Reference< container::XNameAccess >  xNameAccess, xSecond, xThird;
     switch(nType)
     {
+        case ContentTypeId::OUTLINE :
+            if(nMode == EditEntryMode::DELETE)
+            {
+                DeleteOutlineSelections();
+            }
+        break;
+
         case ContentTypeId::TABLE     :
             if(nMode == EditEntryMode::UNPROTECT_TABLE)
             {
@@ -3756,6 +3757,13 @@ void SwContentTree::EditEntry(SvTreeListEntry const * 
pEntry, EditEntryMode nMod
         pDlg->SetForbiddenChars(sForbiddenChars);
         pDlg->Execute();
     }
+    if(EditEntryMode::DELETE == nMode)
+    {
+        m_bViewHasChanged = true;
+        GetParentWindow()->UpdateListBox();
+        TimerUpdate(&m_aUpdTimer);
+        GrabFocus();
+    }
 }
 
 void SwContentTree::GotoContent(const SwContent* pCnt)
_______________________________________________
Libreoffice-commits mailing list
libreoffice-comm...@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits

Reply via email to