Adjust tab ordering in some dialogs

Introduce a shortcut method to set tab ordering and use it in
the dialogs that override the tab traversal orders:

* Eeschema sheet properties
* Pcbnew Move exact
* Pcbnew Move relative

Also set some initial focus fields in the same dialogs.

Tidy a few includes.

Fixes: lp:1816009
* https://bugs.launchpad.net/kicad/+bug/1816009
This commit is contained in:
John Beard 2019-02-23 13:58:57 +00:00
parent 498a566ca3
commit 82734e7116
7 changed files with 136 additions and 13 deletions

View File

@ -225,6 +225,7 @@ set( COMMON_WIDGET_SRCS
widgets/paged_dialog.cpp widgets/paged_dialog.cpp
widgets/progress_reporter.cpp widgets/progress_reporter.cpp
widgets/stepped_slider.cpp widgets/stepped_slider.cpp
widgets/tab_traversal.cpp
widgets/text_ctrl_eval.cpp widgets/text_ctrl_eval.cpp
widgets/two_column_tree_list.cpp widgets/two_column_tree_list.cpp
widgets/ui_common.cpp widgets/ui_common.cpp

View File

@ -0,0 +1,33 @@
/*
* This program source code file is part of KiCad, a free EDA CAD application.
*
* Copyright (C) 2019 KiCad Developers, see CHANGELOG.TXT for contributors.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, you may find one here:
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
* or you may search the http://www.gnu.org website for the version 2 license,
* or you may write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/
#include <widgets/tab_traversal.h>
void KIUI::SetControlsTabOrder( const std::vector<wxWindow*>& aControlsInTabOrder )
{
for( unsigned i = 1; i < aControlsInTabOrder.size(); ++i )
{
aControlsInTabOrder[i]->MoveAfterInTabOrder( aControlsInTabOrder[i - 1] );
}
}

View File

@ -2,7 +2,7 @@
* This program source code file is part of KiCad, a free EDA CAD application. * This program source code file is part of KiCad, a free EDA CAD application.
* *
* Copyright (C) 2009 Wayne Stambaugh <stambaughw@verizon.net> * Copyright (C) 2009 Wayne Stambaugh <stambaughw@verizon.net>
* Copyright (C) 2014-2018 KiCad Developers, see CHANGELOG.TXT for contributors. * Copyright (C) 2014-2019 KiCad Developers, see CHANGELOG.TXT for contributors.
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License * modify it under the terms of the GNU General Public License
@ -22,12 +22,18 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#include <wx/string.h>
#include <sch_edit_frame.h>
#include <dialog_sch_sheet_props.h> #include <dialog_sch_sheet_props.h>
#include <wx/string.h>
#include <confirm.h>
#include <validators.h> #include <validators.h>
#include <wildcards_and_files_ext.h> #include <wildcards_and_files_ext.h>
#include <confirm.h>
#include <widgets/tab_traversal.h>
#include <sch_edit_frame.h>
DIALOG_SCH_SHEET_PROPS::DIALOG_SCH_SHEET_PROPS( SCH_EDIT_FRAME* parent, SCH_SHEET* aSheet ) : DIALOG_SCH_SHEET_PROPS::DIALOG_SCH_SHEET_PROPS( SCH_EDIT_FRAME* parent, SCH_SHEET* aSheet ) :
DIALOG_SCH_SHEET_PROPS_BASE( parent ), DIALOG_SCH_SHEET_PROPS_BASE( parent ),
@ -39,6 +45,17 @@ DIALOG_SCH_SHEET_PROPS::DIALOG_SCH_SHEET_PROPS( SCH_EDIT_FRAME* parent, SCH_SHEE
m_textFileName->SetFocus(); m_textFileName->SetFocus();
m_sdbSizer1OK->SetDefault(); m_sdbSizer1OK->SetDefault();
// Normally, the file and sheet name are the "main" edited fields
// so put them first
KIUI::SetControlsTabOrder( {
m_textFileName,
m_textSheetName,
m_filenameSizeCtrl,
m_sheetnameSizeCtrl,
} );
SetInitialFocus( m_textFileName );
// Now all widgets have the size fixed, call FinishDialogSettings // Now all widgets have the size fixed, call FinishDialogSettings
FinishDialogSettings(); FinishDialogSettings();

View File

@ -0,0 +1,55 @@
/*
* This program source code file is part of KiCad, a free EDA CAD application.
*
* Copyright (C) 2019 KiCad Developers, see CHANGELOG.TXT for contributors.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, you may find one here:
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
* or you may search the http://www.gnu.org website for the version 2 license,
* or you may write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/
#ifndef WIDGETS_TAB_TRAVERSAL__H
#define WIDGETS_TAB_TRAVERSAL__H
/**
* @file
* Functions for manipulating tab traversal in forms and dialogs.
*/
#include <wx/window.h>
#include <vector>
namespace KIUI
{
/**
* Set a list of controls to have a defined sequential tab order.
*
* Each control in the list will come after the previous one. The first control will
* keep its current position. The end result will be that the given control
* will be sequential when tabbed though.
*
* This can be slightly clearer than manually calling MoveAfterInTabOrder
* on each control in turn.
*
* @param aControlsInTabOrder list of controls (wxWindows) in desired tab order
*/
void SetControlsTabOrder( const std::vector<wxWindow*>& aControlsInTabOrder );
} // namespace KIUI
#endif // WIDGETS_TAB_TRAVERSAL__H

View File

@ -22,9 +22,11 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#include <pcb_edit_frame.h> #include <dialogs/dialog_move_exact.h>
#include "dialog_move_exact.h" #include <widgets/tab_traversal.h>
#include <pcb_edit_frame.h>
// initialise statics // initialise statics
DIALOG_MOVE_EXACT::MOVE_EXACT_OPTIONS DIALOG_MOVE_EXACT::m_options; DIALOG_MOVE_EXACT::MOVE_EXACT_OPTIONS DIALOG_MOVE_EXACT::m_options;
@ -41,8 +43,12 @@ DIALOG_MOVE_EXACT::DIALOG_MOVE_EXACT( PCB_BASE_FRAME *aParent, wxPoint& aTransla
m_rotate( aParent, m_rotLabel, m_rotEntry, m_rotUnit ) m_rotate( aParent, m_rotLabel, m_rotEntry, m_rotUnit )
{ {
// tabbing goes through the entries in sequence // tabbing goes through the entries in sequence
m_yEntry->MoveAfterInTabOrder( m_xEntry ); KIUI::SetControlsTabOrder( {
m_rotEntry->MoveAfterInTabOrder( m_yEntry ); m_xEntry,
m_yEntry,
m_rotEntry,
m_anchorOptions,
} );
updateDialogControls( m_options.polarCoords ); updateDialogControls( m_options.polarCoords );

View File

@ -28,7 +28,10 @@
#include <vector> #include <vector>
#include <widgets/unit_binder.h> #include <widgets/unit_binder.h>
#include <dialog_move_exact_base.h> #include <dialogs/dialog_move_exact_base.h>
class PCB_BASE_FRAME;
enum ROTATION_ANCHOR enum ROTATION_ANCHOR

View File

@ -21,10 +21,13 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/ */
#include <pcb_edit_frame.h> #include <dialogs/dialog_position_relative.h>
#include "tools/pcb_actions.h"
#include "dialog_position_relative.h" #include <tools/pcb_actions.h>
#include <widgets/tab_traversal.h>
#include <pcb_edit_frame.h>
// initialise statics // initialise statics
DIALOG_POSITION_RELATIVE::POSITION_RELATIVE_OPTIONS DIALOG_POSITION_RELATIVE::m_options; DIALOG_POSITION_RELATIVE::POSITION_RELATIVE_OPTIONS DIALOG_POSITION_RELATIVE::m_options;
@ -40,7 +43,12 @@ DIALOG_POSITION_RELATIVE::DIALOG_POSITION_RELATIVE( PCB_BASE_FRAME* aParent, wxP
m_yOffset( aParent, m_yLabel, m_yEntry, m_yUnit ) m_yOffset( aParent, m_yLabel, m_yEntry, m_yUnit )
{ {
// tabbing goes through the entries in sequence // tabbing goes through the entries in sequence
m_yEntry->MoveAfterInTabOrder( m_xEntry ); KIUI::SetControlsTabOrder( {
m_xEntry,
m_yEntry,
} );
SetInitialFocus( m_xEntry );
// and set up the entries according to the saved options // and set up the entries according to the saved options
m_polarCoords->SetValue( m_options.polarCoords ); m_polarCoords->SetValue( m_options.polarCoords );