diff options
author | Heiko Tietze <tietze.heiko@gmail.com> | 2024-09-10 10:14:51 +0200 |
---|---|---|
committer | Heiko Tietze <heiko.tietze@documentfoundation.org> | 2024-09-26 16:10:16 +0200 |
commit | 2ac51182e63c109bb44334f86b6ab3bcdf247494 (patch) | |
tree | 9b2c685dcf1d4d665d57978608294dd01fca90bb /vcl | |
parent | 70a183875aaa11f3099b8280ff76cff1a3db0d2b (diff) |
Related tdf#146906 - Remove hard-coded access to split window
* Calc users can customize .uno:SplitWindow
* Help modification in I00f75b4481a5795674a3a18eea7ca8701dc542fc
Change-Id: I9d3692640d7bfb6283445cf7f103986cf72581af
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/173122
Reviewed-by: Heiko Tietze <heiko.tietze@documentfoundation.org>
Tested-by: Jenkins
Diffstat (limited to 'vcl')
-rw-r--r-- | vcl/source/window/taskpanelist.cxx | 52 |
1 files changed, 5 insertions, 47 deletions
diff --git a/vcl/source/window/taskpanelist.cxx b/vcl/source/window/taskpanelist.cxx index 16747f0c08e1..01680eedbe31 100644 --- a/vcl/source/window/taskpanelist.cxx +++ b/vcl/source/window/taskpanelist.cxx @@ -133,7 +133,7 @@ bool TaskPaneList::IsInList( vcl::Window *pWindow ) bool TaskPaneList::IsCycleKey(const vcl::KeyCode& rKeyCode) { - return rKeyCode.GetCode() == KEY_F6 && !rKeyCode.IsMod2(); // F6 + return rKeyCode.GetCode() == KEY_F6 && !rKeyCode.IsMod2() && !rKeyCode.IsShift(); // F6 } bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) @@ -152,8 +152,6 @@ bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) bool bForward = !aKeyCode.IsShift(); if (TaskPaneList::IsCycleKey(aKeyCode)) { - bool bSplitterOnly = aKeyCode.IsMod1() && aKeyCode.IsShift(); - // is the focus in the list ? auto p = std::find_if(mTaskPanes.begin(), mTaskPanes.end(), [](const VclPtr<vcl::Window>& rWinPtr) { return rWinPtr->HasChildPathFocus( true ); }); @@ -162,7 +160,7 @@ bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) vcl::Window *pWin = p->get(); // Ctrl-F6 goes directly to the document - if( !pWin->IsDialog() && aKeyCode.IsMod1() && !aKeyCode.IsShift() ) + if( !pWin->IsDialog() && aKeyCode.IsMod1() ) { pWin->ImplGrabFocusToDocument( GetFocusFlags::F6 ); return true; @@ -171,10 +169,7 @@ bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) // activate next task pane vcl::Window *pNextWin = nullptr; - if( bSplitterOnly ) - pNextWin = FindNextSplitter( *p ); - else - pNextWin = FindNextFloat( *p, bForward ); + pNextWin = FindNextFloat( *p, bForward ); if( pNextWin != pWin ) { @@ -184,10 +179,6 @@ bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) } else { - // forward key if no splitter found - if( bSplitterOnly ) - return false; - // we did not find another taskpane, so // put focus back into document pWin->ImplGrabFocusToDocument( GetFocusFlags::F6 | (bForward ? GetFocusFlags::Forward : GetFocusFlags::Backward)); @@ -198,10 +189,8 @@ bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) // the focus is not in the list: activate first float if F6 was pressed vcl::Window *pWin; - if( bSplitterOnly ) - pWin = FindNextSplitter( nullptr ); - else - pWin = FindNextFloat( nullptr, bForward ); + + pWin = FindNextFloat( nullptr, bForward ); if( pWin ) { ImplTaskPaneListGrabFocus( pWin, bForward ); @@ -212,37 +201,6 @@ bool TaskPaneList::HandleKeyEvent(const KeyEvent& rKeyEvent) return false; } -// returns next splitter -vcl::Window* TaskPaneList::FindNextSplitter( vcl::Window *pWindow ) -{ - ::std::stable_sort( mTaskPanes.begin(), mTaskPanes.end(), LTRSort() ); - - auto p = mTaskPanes.begin(); - if( pWindow ) - p = std::find(mTaskPanes.begin(), mTaskPanes.end(), pWindow); - - if( p != mTaskPanes.end() ) - { - unsigned n = mTaskPanes.size(); - while( --n ) - { - if( pWindow ) // increment before test - ++p; - if( p == mTaskPanes.end() ) - p = mTaskPanes.begin(); - if( (*p)->ImplIsSplitter() && (*p)->IsReallyVisible() && !(*p)->IsDialog() && (*p)->GetParent()->HasChildPathFocus() ) - { - pWindow = (*p).get(); - break; - } - if( !pWindow ) // increment after test, otherwise first element is skipped - ++p; - } - } - - return pWindow; -} - // returns first valid item (regardless of type) if pWindow==0, otherwise returns next valid float vcl::Window* TaskPaneList::FindNextFloat( vcl::Window *pWindow, bool bForward ) { |