summaryrefslogtreecommitdiff
path: root/vcl
diff options
context:
space:
mode:
authorHeiko Tietze <tietze.heiko@gmail.com>2024-09-10 10:14:51 +0200
committerHeiko Tietze <heiko.tietze@documentfoundation.org>2024-09-26 16:10:16 +0200
commit2ac51182e63c109bb44334f86b6ab3bcdf247494 (patch)
tree9b2c685dcf1d4d665d57978608294dd01fca90bb /vcl
parent70a183875aaa11f3099b8280ff76cff1a3db0d2b (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.cxx52
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 )
{