From 8cc2115c8cadf938166bb94038da6c1bc61f0fc5 Mon Sep 17 00:00:00 2001 From: Szymon Kłos Date: Mon, 20 Jul 2015 10:04:09 +0200 Subject: accessibility: correct tab-order Change-Id: Ib554e8bb73367d5f85253f0deb083fbc5a5d454b --- fpicker/source/office/RemoteFilesDialog.cxx | 64 +++++++++++++++++++++++------ 1 file changed, 52 insertions(+), 12 deletions(-) (limited to 'fpicker') diff --git a/fpicker/source/office/RemoteFilesDialog.cxx b/fpicker/source/office/RemoteFilesDialog.cxx index 86be5225fdbb..bb2587d1acc4 100644 --- a/fpicker/source/office/RemoteFilesDialog.cxx +++ b/fpicker/source/office/RemoteFilesDialog.cxx @@ -11,13 +11,22 @@ class FileViewContainer : public vcl::Window { + enum FocusState + { + Prev = 0, + TreeView, + FileView, + Next, + FocusCount + }; + private: VclPtr< SvtFileView > m_pFileView; VclPtr< FolderTree > m_pTreeView; VclPtr< Splitter > m_pSplitter; int m_nCurrentFocus; - VclPtr m_pFocusWidgets[4]; + VclPtr m_pFocusWidgets[FocusState::FocusCount]; public: FileViewContainer( vcl::Window *pParent ) @@ -51,10 +60,10 @@ class FileViewContainer : public vcl::Window m_pFileView = pFileView; m_pTreeView = pTreeView; m_pSplitter = pSplitter; - m_pFocusWidgets[0] = pPrevSibling; - m_pFocusWidgets[1] = pTreeView; - m_pFocusWidgets[2] = pFileView; - m_pFocusWidgets[3] = pNextSibling; + m_pFocusWidgets[FocusState::Prev] = pPrevSibling; + m_pFocusWidgets[FocusState::TreeView] = pTreeView; + m_pFocusWidgets[FocusState::FileView] = pFileView; + m_pFocusWidgets[FocusState::Next] = pNextSibling; } virtual void Resize() SAL_OVERRIDE @@ -89,14 +98,20 @@ class FileViewContainer : public vcl::Window if( !m_pFileView || !m_pTreeView ) return; - if( !bReverse && m_nCurrentFocus < 3 ) + if( bReverse && m_nCurrentFocus > FocusState::Prev && m_nCurrentFocus <= FocusState::Next ) { - m_pFocusWidgets[++m_nCurrentFocus]->SetFakeFocus( true ); + m_pFocusWidgets[m_nCurrentFocus]->SetFakeFocus(false); + m_pFocusWidgets[m_nCurrentFocus]->LoseFocus(); + + m_pFocusWidgets[--m_nCurrentFocus]->SetFakeFocus( true ); m_pFocusWidgets[m_nCurrentFocus]->GrabFocus(); } - else if( m_nCurrentFocus > 0 ) + else if( !bReverse && m_nCurrentFocus >= FocusState::Prev && m_nCurrentFocus < FocusState::Next ) { - m_pFocusWidgets[--m_nCurrentFocus]->SetFakeFocus( true ); + m_pFocusWidgets[m_nCurrentFocus]->SetFakeFocus(false); + m_pFocusWidgets[m_nCurrentFocus]->LoseFocus(); + + m_pFocusWidgets[++m_nCurrentFocus]->SetFakeFocus( true ); m_pFocusWidgets[m_nCurrentFocus]->GrabFocus(); } } @@ -106,13 +121,38 @@ class FileViewContainer : public vcl::Window if( !m_pFileView || !m_pTreeView ) return; - m_nCurrentFocus = 1; - m_pFocusWidgets[m_nCurrentFocus]->SetFakeFocus( true ); - m_pFocusWidgets[m_nCurrentFocus]->GrabFocus(); + GetFocusFlags aFlags = GetGetFocusFlags(); + + if( aFlags & GetFocusFlags::Forward ) + m_nCurrentFocus = FocusState::TreeView; + else if( aFlags & GetFocusFlags::Backward ) + m_nCurrentFocus = FocusState::FileView; + + if( m_nCurrentFocus >= FocusState::Prev && m_nCurrentFocus <= FocusState::Next ) + { + m_pFocusWidgets[m_nCurrentFocus]->SetFakeFocus( true ); + m_pFocusWidgets[m_nCurrentFocus]->GrabFocus(); + } } virtual bool Notify( NotifyEvent& rNEvt ) SAL_OVERRIDE { + if( rNEvt.GetType() == MouseNotifyEvent::GETFOCUS ) + { + // we must also update counter when user change focus using mouse + for(int i = FocusState::Prev; i <= FocusState::Next; i++) + { + if( rNEvt.GetWindow() == m_pFocusWidgets[i] ) + { + m_nCurrentFocus = i; + return true; + } + } + + // GETFOCUS for one of FileView's subcontrols + m_nCurrentFocus = FocusState::FileView; + return true; + } if( rNEvt.GetType() == MouseNotifyEvent::KEYINPUT ) { const KeyEvent* pKeyEvent = rNEvt.GetKeyEvent(); -- cgit