Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
K
kicad-source-mirror
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
kicad-source-mirror
Commits
e0a0f596
Commit
e0a0f596
authored
Oct 04, 2013
by
Dick Hollenbeck
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add keyboard support to DIALOG_FP_LIB_TABLE grid interface:
CTL+X, CTL+V, CTL+A, CTL+C
parent
bf26962f
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
167 additions
and
117 deletions
+167
-117
dialog_fp_lib_table.cpp
pcbnew/dialogs/dialog_fp_lib_table.cpp
+152
-106
dialog_fp_lib_table_base.cpp
pcbnew/dialogs/dialog_fp_lib_table_base.cpp
+6
-2
dialog_fp_lib_table_base.fbp
pcbnew/dialogs/dialog_fp_lib_table_base.fbp
+8
-8
dialog_fp_lib_table_base.h
pcbnew/dialogs/dialog_fp_lib_table_base.h
+1
-1
No files found.
pcbnew/dialogs/dialog_fp_lib_table.cpp
View file @
e0a0f596
...
@@ -26,18 +26,13 @@
...
@@ -26,18 +26,13 @@
/* TODO:
/* TODO:
*) Check for duplicate nicknames per table
*) Grab text from any pending ChoiceEditor when OK button pressed.
*) Grab text from any pending ChoiceEditor when OK button pressed.
*) Test wxRE_ADVANCED on Windows.
*) Test wxRE_ADVANCED on Windows.
*) Do environment variable substitution on lookup
*/
*/
#include <fctsys.h>
#include <fctsys.h>
#include <dialog_fp_lib_table_base.h>
#include <dialog_fp_lib_table_base.h>
#include <fp_lib_table.h>
#include <fp_lib_table.h>
...
@@ -224,6 +219,12 @@ public:
...
@@ -224,6 +219,12 @@ public:
#define ROW_SEP wxT( '\n' )
#define ROW_SEP wxT( '\n' )
inline
bool
isCtl
(
int
aChar
,
const
wxKeyEvent
&
e
)
{
return
e
.
GetKeyCode
()
==
aChar
&&
e
.
ControlDown
()
&&
!
e
.
AltDown
()
&&
!
e
.
ShiftDown
()
&&
!
e
.
MetaDown
();
}
/**
/**
* Class DIALOG_FP_LIB_TABLE
* Class DIALOG_FP_LIB_TABLE
* shows and edits the PCB library tables. Two tables are expected, one global
* shows and edits the PCB library tables. Two tables are expected, one global
...
@@ -235,9 +236,11 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
...
@@ -235,9 +236,11 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
enum
enum
{
{
ID_CUT
,
// = wxID_HIGHEST + 1,
MYID_CUT
,
// = wxID_HIGHEST + 1,
ID_COPY
,
MYID_COPY
,
ID_PASTE
,
MYID_PASTE
,
MYID_SELECT
,
MYID_SENTINEL
,
};
};
// row & col "selection" acquisition
// row & col "selection" acquisition
...
@@ -295,17 +298,18 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
...
@@ -295,17 +298,18 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
{
{
wxMenu
menu
;
wxMenu
menu
;
menu
.
Append
(
ID_CUT
,
_
(
"Cut"
),
_
(
"Clear selected cells"
)
);
menu
.
Append
(
MYID_CUT
,
_
(
"Cut
\t
CTRL+X"
),
_
(
"Clear selected cells pasting original contents to clipboard"
)
);
menu
.
Append
(
ID_COPY
,
_
(
"Copy"
),
_
(
"Copy selected cells to clipboard"
)
);
menu
.
Append
(
MYID_COPY
,
_
(
"Copy
\t
CTRL+C"
),
_
(
"Copy selected cells to clipboard"
)
);
menu
.
Append
(
ID_PASTE
,
_
(
"Paste"
),
_
(
"Paste clipboard cells to matrix at current cell"
)
);
menu
.
Append
(
MYID_PASTE
,
_
(
"Paste
\t
CTRL+V"
),
_
(
"Paste clipboard cells to matrix at current cell"
)
);
menu
.
Append
(
MYID_SELECT
,
_
(
"Select All
\t
CTRL+A"
),
_
(
"Select all cells"
)
);
getSelectedArea
();
getSelectedArea
();
// if nothing is selected, disable cut and copy.
// if nothing is selected, disable cut and copy.
if
(
!
selRowCount
&&
!
selColCount
)
if
(
!
selRowCount
&&
!
selColCount
)
{
{
menu
.
Enable
(
ID_CUT
,
false
);
menu
.
Enable
(
MY
ID_CUT
,
false
);
menu
.
Enable
(
ID_COPY
,
false
);
menu
.
Enable
(
MY
ID_COPY
,
false
);
}
}
bool
have_cb_text
=
false
;
bool
have_cb_text
=
false
;
...
@@ -320,137 +324,151 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
...
@@ -320,137 +324,151 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
if
(
!
have_cb_text
)
if
(
!
have_cb_text
)
{
{
// if nothing on clipboard, disable paste.
// if nothing on clipboard, disable paste.
menu
.
Enable
(
ID_PASTE
,
false
);
menu
.
Enable
(
MY
ID_PASTE
,
false
);
}
}
// if there is no current cell cursor, disable paste.
// if there is no current cell cursor, disable paste.
else
if
(
m_cur_row
==
-
1
||
m_cur_col
==
-
1
)
else
if
(
m_cur_row
==
-
1
||
m_cur_col
==
-
1
)
menu
.
Enable
(
ID_PASTE
,
false
);
menu
.
Enable
(
MY
ID_PASTE
,
false
);
PopupMenu
(
&
menu
);
PopupMenu
(
&
menu
);
// passOnFocus();
// passOnFocus();
}
}
// the user clicked on a popup menu choice:
void
cutcopy
(
bool
doCut
)
void
onPopupSelection
(
wxCommandEvent
&
event
)
{
{
int
menuId
=
event
.
GetId
();
// this format is compatible with most spreadsheets
if
(
wxTheClipboard
->
Open
()
)
// assume getSelectedArea() was called by rightClickPopupMenu() and there's
// no way to have gotten here without that having been called.
switch
(
menuId
)
{
{
case
ID_CUT
:
wxGridTableBase
*
tbl
=
m_cur_grid
->
GetTable
();
case
ID_COPY
:
wxString
txt
;
// this format is compatible with most spreadsheets
if
(
wxTheClipboard
->
Open
()
)
{
wxGridTableBase
*
tbl
=
m_cur_grid
->
GetTable
();
wxString
txt
;
for
(
int
row
=
selRowStart
;
row
<
selRowStart
+
selRowCount
;
++
row
)
for
(
int
row
=
selRowStart
;
row
<
selRowStart
+
selRowCount
;
++
row
)
{
for
(
int
col
=
selColStart
;
col
<
selColStart
+
selColCount
;
++
col
)
{
{
for
(
int
col
=
selColStart
;
col
<
selColStart
+
selColCount
;
++
col
)
txt
+=
tbl
->
GetValue
(
row
,
col
);
{
txt
+=
tbl
->
GetValue
(
row
,
col
);
if
(
col
<
selColStart
+
selColCount
-
1
)
// that was not last column
if
(
col
<
selColStart
+
selColCount
-
1
)
// that was not last column
txt
+=
COL_SEP
;
txt
+=
COL_SEP
;
if
(
menuId
==
ID_CUT
)
if
(
doCut
)
tbl
->
SetValue
(
row
,
col
,
wxEmptyString
);
tbl
->
SetValue
(
row
,
col
,
wxEmptyString
);
}
txt
+=
ROW_SEP
;
}
}
txt
+=
ROW_SEP
;
wxTheClipboard
->
SetData
(
new
wxTextDataObject
(
txt
)
);
wxTheClipboard
->
Close
();
m_cur_grid
->
ForceRefresh
();
}
}
break
;
case
ID_PASTE
:
wxTheClipboard
->
SetData
(
new
wxTextDataObject
(
txt
)
);
D
(
printf
(
"paste
\n
"
);)
wxTheClipboard
->
Close
();
// assume format came from a spreadsheet or us.
m_cur_grid
->
ForceRefresh
();
if
(
wxTheClipboard
->
Open
()
)
}
{
}
if
(
wxTheClipboard
->
IsSupported
(
wxDF_TEXT
)
)
{
wxTextDataObject
data
;
FP_TBL_MODEL
*
tbl
=
(
FP_TBL_MODEL
*
)
m_cur_grid
->
GetTable
();
wxTheClipboard
->
GetData
(
data
);
void
paste
()
{
D
(
printf
(
"paste
\n
"
);)
// assume format came from a spreadsheet or us.
if
(
wxTheClipboard
->
Open
()
)
{
if
(
wxTheClipboard
->
IsSupported
(
wxDF_TEXT
)
)
{
wxTextDataObject
data
;
FP_TBL_MODEL
*
tbl
=
(
FP_TBL_MODEL
*
)
m_cur_grid
->
GetTable
();
wxString
cb_text
=
data
.
GetText
();
wxTheClipboard
->
GetData
(
data
);
size_t
ndx
=
cb_text
.
find_first_of
(
wxT
(
"(fp_lib_table "
)
);
if
(
ndx
!=
std
::
string
::
npos
)
wxString
cb_text
=
data
.
GetText
();
{
size_t
ndx
=
cb_text
.
find
(
wxT
(
"(fp_lib_table "
)
);
// paste the ROWs of s-expression (fp_lib_table), starting
// at column 0 regardless of current cursor column.
STRING_LINE_READER
slr
(
TO_UTF8
(
cb_text
),
wxT
(
"Clipboard"
)
);
if
(
ndx
!=
std
::
string
::
npos
)
FP_LIB_TABLE_LEXER
lexer
(
&
slr
);
{
FP_LIB_TABLE
tmp_tbl
;
// paste the ROWs of s-expression (fp_lib_table), starting
bool
parsed
=
true
;
// at column 0 regardless of current cursor column.
try
STRING_LINE_READER
slr
(
TO_UTF8
(
cb_text
),
wxT
(
"Clipboard"
)
);
{
FP_LIB_TABLE_LEXER
lexer
(
&
slr
);
tmp_tbl
.
Parse
(
&
lexer
);
FP_LIB_TABLE
tmp_tbl
;
}
bool
parsed
=
true
;
catch
(
PARSE_ERROR
&
pe
)
{
// @todo tell what line and offset
parsed
=
false
;
}
if
(
parsed
)
try
{
{
// if clipboard rows would extend past end of current table size...
tmp_tbl
.
Parse
(
&
lexer
);
if
(
int
(
tmp_tbl
.
rows
.
size
()
)
>
tbl
->
GetNumberRows
()
-
m_cur_row
)
{
int
newRowsNeeded
=
tmp_tbl
.
rows
.
size
()
-
(
tbl
->
GetNumberRows
()
-
m_cur_row
);
tbl
->
AppendRows
(
newRowsNeeded
);
}
for
(
int
i
=
0
;
i
<
(
int
)
tmp_tbl
.
rows
.
size
();
++
i
)
{
tbl
->
rows
[
m_cur_row
+
i
]
=
tmp_tbl
.
rows
[
i
];
}
}
m_cur_grid
->
AutoSizeColumns
();
}
}
else
catch
(
PARSE_ERROR
&
pe
)
{
{
wxStringTokenizer
rows
(
cb_text
,
ROW_SEP
,
wxTOKEN_RET_EMPTY
);
// @todo tell what line and offset
parsed
=
false
;
}
if
(
parsed
)
{
// if clipboard rows would extend past end of current table size...
// if clipboard rows would extend past end of current table size...
if
(
int
(
rows
.
CountTokens
()
)
>
tbl
->
GetNumberRows
()
-
m_cur_row
)
if
(
int
(
tmp_tbl
.
rows
.
size
()
)
>
tbl
->
GetNumberRows
()
-
m_cur_row
)
{
{
int
newRowsNeeded
=
rows
.
CountTokens
()
-
(
tbl
->
GetNumberRows
()
-
m_cur_row
);
int
newRowsNeeded
=
tmp_tbl
.
rows
.
size
()
-
(
tbl
->
GetNumberRows
()
-
m_cur_row
);
tbl
->
AppendRows
(
newRowsNeeded
);
tbl
->
AppendRows
(
newRowsNeeded
);
}
}
for
(
int
row
=
m_cur_row
;
rows
.
HasMoreTokens
();
++
row
)
for
(
int
i
=
0
;
i
<
(
int
)
tmp_tbl
.
rows
.
size
();
++
i
)
{
{
wxString
rowTxt
=
rows
.
GetNextToken
();
tbl
->
rows
[
m_cur_row
+
i
]
=
tmp_tbl
.
rows
[
i
];
}
}
m_cur_grid
->
AutoSizeColumns
();
}
else
{
wxStringTokenizer
rows
(
cb_text
,
ROW_SEP
,
wxTOKEN_RET_EMPTY
);
wxStringTokenizer
cols
(
rowTxt
,
COL_SEP
,
wxTOKEN_RET_EMPTY
);
// if clipboard rows would extend past end of current table size...
if
(
int
(
rows
.
CountTokens
()
)
>
tbl
->
GetNumberRows
()
-
m_cur_row
)
{
int
newRowsNeeded
=
rows
.
CountTokens
()
-
(
tbl
->
GetNumberRows
()
-
m_cur_row
);
tbl
->
AppendRows
(
newRowsNeeded
);
}
for
(
int
col
=
m_cur_col
;
cols
.
HasMoreTokens
();
++
col
)
for
(
int
row
=
m_cur_row
;
rows
.
HasMoreTokens
();
++
row
)
{
{
wxString
cellTxt
=
cols
.
GetNextToken
();
wxString
rowTxt
=
rows
.
GetNextToken
();
tbl
->
SetValue
(
row
,
col
,
cellTxt
);
}
wxStringTokenizer
cols
(
rowTxt
,
COL_SEP
,
wxTOKEN_RET_EMPTY
);
for
(
int
col
=
m_cur_col
;
cols
.
HasMoreTokens
();
++
col
)
{
wxString
cellTxt
=
cols
.
GetNextToken
();
tbl
->
SetValue
(
row
,
col
,
cellTxt
);
}
}
}
}
}
}
wxTheClipboard
->
Close
();
m_cur_grid
->
ForceRefresh
();
}
}
wxTheClipboard
->
Close
();
m_cur_grid
->
ForceRefresh
();
}
}
// the user clicked on a popup menu choice:
void
onPopupSelection
(
wxCommandEvent
&
event
)
{
int
menuId
=
event
.
GetId
();
// assume getSelectedArea() was called by rightClickPopupMenu() and there's
// no way to have gotten here without that having been called.
switch
(
menuId
)
{
case
MYID_CUT
:
case
MYID_COPY
:
cutcopy
(
menuId
==
MYID_CUT
);
break
;
case
MYID_PASTE
:
paste
();
break
;
case
MYID_SELECT
:
m_cur_grid
->
SelectAll
();
break
;
break
;
}
}
}
}
...
@@ -552,6 +570,31 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
...
@@ -552,6 +570,31 @@ class DIALOG_FP_LIB_TABLE : public DIALOG_FP_LIB_TABLE_BASE
//-----<event handlers>----------------------------------
//-----<event handlers>----------------------------------
void
onKeyDown
(
wxKeyEvent
&
ev
)
{
if
(
isCtl
(
'A'
,
ev
)
)
{
m_cur_grid
->
SelectAll
();
}
else
if
(
isCtl
(
'C'
,
ev
)
)
{
getSelectedArea
();
cutcopy
(
false
);
}
else
if
(
isCtl
(
'V'
,
ev
)
)
{
getSelectedArea
();
paste
();
}
else
if
(
isCtl
(
'X'
,
ev
)
)
{
getSelectedArea
();
cutcopy
(
true
);
}
else
ev
.
Skip
();
}
void
pageChangedHandler
(
wxAuiNotebookEvent
&
event
)
void
pageChangedHandler
(
wxAuiNotebookEvent
&
event
)
{
{
int
pageNdx
=
m_auinotebook
->
GetSelection
();
int
pageNdx
=
m_auinotebook
->
GetSelection
();
...
@@ -822,7 +865,7 @@ public:
...
@@ -822,7 +865,7 @@ public:
m_global_grid
->
AutoSizeColumns
();
m_global_grid
->
AutoSizeColumns
();
m_project_grid
->
AutoSizeColumns
();
m_project_grid
->
AutoSizeColumns
();
Connect
(
ID_CUT
,
ID_PASTE
,
wxEVT_COMMAND_MENU_SELECTED
,
Connect
(
MYID_CUT
,
MYID_SENTINEL
-
1
,
wxEVT_COMMAND_MENU_SELECTED
,
wxCommandEventHandler
(
DIALOG_FP_LIB_TABLE
::
onPopupSelection
),
NULL
,
this
);
wxCommandEventHandler
(
DIALOG_FP_LIB_TABLE
::
onPopupSelection
),
NULL
,
this
);
populateEnvironReadOnlyTable
();
populateEnvironReadOnlyTable
();
...
@@ -834,11 +877,14 @@ public:
...
@@ -834,11 +877,14 @@ public:
// fire pageChangedHandler() so m_cur_grid gets set
// fire pageChangedHandler() so m_cur_grid gets set
wxAuiNotebookEvent
uneventful
;
wxAuiNotebookEvent
uneventful
;
pageChangedHandler
(
uneventful
);
pageChangedHandler
(
uneventful
);
// for ALT+A handling, we want the initial focus to be on the first selected grid.
m_cur_grid
->
SetFocus
();
}
}
~
DIALOG_FP_LIB_TABLE
()
~
DIALOG_FP_LIB_TABLE
()
{
{
Disconnect
(
ID_CUT
,
ID_PASTE
,
wxEVT_COMMAND_MENU_SELECTED
,
Disconnect
(
MYID_CUT
,
MYID_SENTINEL
-
1
,
wxEVT_COMMAND_MENU_SELECTED
,
wxCommandEventHandler
(
DIALOG_FP_LIB_TABLE
::
onPopupSelection
),
NULL
,
this
);
wxCommandEventHandler
(
DIALOG_FP_LIB_TABLE
::
onPopupSelection
),
NULL
,
this
);
// ~wxGrid() examines its table, and the tables will have been destroyed before
// ~wxGrid() examines its table, and the tables will have been destroyed before
...
...
pcbnew/dialogs/dialog_fp_lib_table_base.cpp
View file @
e0a0f596
...
@@ -194,16 +194,18 @@ DIALOG_FP_LIB_TABLE_BASE::DIALOG_FP_LIB_TABLE_BASE( wxWindow* parent, wxWindowID
...
@@ -194,16 +194,18 @@ DIALOG_FP_LIB_TABLE_BASE::DIALOG_FP_LIB_TABLE_BASE( wxWindow* parent, wxWindowID
this
->
Centre
(
wxBOTH
);
this
->
Centre
(
wxBOTH
);
// Connect Events
// Connect Events
this
->
Connect
(
wxEVT_
INIT_DIALOG
,
wxInitDialogEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onInitDialog
)
);
this
->
Connect
(
wxEVT_
KEY_DOWN
,
wxKeyEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onKeyDown
)
);
m_auinotebook
->
Connect
(
wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED
,
wxAuiNotebookEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
pageChangedHandler
),
NULL
,
this
);
m_auinotebook
->
Connect
(
wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED
,
wxAuiNotebookEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
pageChangedHandler
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_global_grid
->
Connect
(
wxEVT_KEY_DOWN
,
wxKeyEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onKeyDown
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_project_grid
->
Connect
(
wxEVT_KEY_DOWN
,
wxKeyEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onKeyDown
),
NULL
,
this
);
m_append_button
->
Connect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
appendRowHandler
),
NULL
,
this
);
m_append_button
->
Connect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
appendRowHandler
),
NULL
,
this
);
m_delete_button
->
Connect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
deleteRowHandler
),
NULL
,
this
);
m_delete_button
->
Connect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
deleteRowHandler
),
NULL
,
this
);
m_move_up_button
->
Connect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
moveUpHandler
),
NULL
,
this
);
m_move_up_button
->
Connect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
moveUpHandler
),
NULL
,
this
);
...
@@ -216,16 +218,18 @@ DIALOG_FP_LIB_TABLE_BASE::DIALOG_FP_LIB_TABLE_BASE( wxWindow* parent, wxWindowID
...
@@ -216,16 +218,18 @@ DIALOG_FP_LIB_TABLE_BASE::DIALOG_FP_LIB_TABLE_BASE( wxWindow* parent, wxWindowID
DIALOG_FP_LIB_TABLE_BASE
::~
DIALOG_FP_LIB_TABLE_BASE
()
DIALOG_FP_LIB_TABLE_BASE
::~
DIALOG_FP_LIB_TABLE_BASE
()
{
{
// Disconnect Events
// Disconnect Events
this
->
Disconnect
(
wxEVT_
INIT_DIALOG
,
wxInitDialogEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onInitDialog
)
);
this
->
Disconnect
(
wxEVT_
KEY_DOWN
,
wxKeyEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onKeyDown
)
);
m_auinotebook
->
Disconnect
(
wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED
,
wxAuiNotebookEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
pageChangedHandler
),
NULL
,
this
);
m_auinotebook
->
Disconnect
(
wxEVT_COMMAND_AUINOTEBOOK_PAGE_CHANGED
,
wxAuiNotebookEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
pageChangedHandler
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_global_grid
->
Disconnect
(
wxEVT_KEY_DOWN
,
wxKeyEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onKeyDown
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftClick
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_CELL_LEFT_DCLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellLeftDClick
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_CELL_RIGHT_CLICK
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCellRightClick
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_GRID_SELECT_CELL
,
wxGridEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onGridCmdSelectCell
),
NULL
,
this
);
m_project_grid
->
Disconnect
(
wxEVT_KEY_DOWN
,
wxKeyEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
onKeyDown
),
NULL
,
this
);
m_append_button
->
Disconnect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
appendRowHandler
),
NULL
,
this
);
m_append_button
->
Disconnect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
appendRowHandler
),
NULL
,
this
);
m_delete_button
->
Disconnect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
deleteRowHandler
),
NULL
,
this
);
m_delete_button
->
Disconnect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
deleteRowHandler
),
NULL
,
this
);
m_move_up_button
->
Disconnect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
moveUpHandler
),
NULL
,
this
);
m_move_up_button
->
Disconnect
(
wxEVT_LEFT_DOWN
,
wxMouseEventHandler
(
DIALOG_FP_LIB_TABLE_BASE
::
moveUpHandler
),
NULL
,
this
);
...
...
pcbnew/dialogs/dialog_fp_lib_table_base.fbp
View file @
e0a0f596
...
@@ -65,8 +65,8 @@
...
@@ -65,8 +65,8 @@
<event
name=
"OnHibernate"
></event>
<event
name=
"OnHibernate"
></event>
<event
name=
"OnIconize"
></event>
<event
name=
"OnIconize"
></event>
<event
name=
"OnIdle"
></event>
<event
name=
"OnIdle"
></event>
<event
name=
"OnInitDialog"
>
onInitDialog
</event>
<event
name=
"OnInitDialog"
></event>
<event
name=
"OnKeyDown"
></event>
<event
name=
"OnKeyDown"
>
onKeyDown
</event>
<event
name=
"OnKeyUp"
></event>
<event
name=
"OnKeyUp"
></event>
<event
name=
"OnKillFocus"
></event>
<event
name=
"OnKillFocus"
></event>
<event
name=
"OnLeaveWindow"
></event>
<event
name=
"OnLeaveWindow"
></event>
...
@@ -396,7 +396,7 @@
...
@@ -396,7 +396,7 @@
<event
name=
"OnGridRangeSelect"
></event>
<event
name=
"OnGridRangeSelect"
></event>
<event
name=
"OnGridRowSize"
></event>
<event
name=
"OnGridRowSize"
></event>
<event
name=
"OnGridSelectCell"
></event>
<event
name=
"OnGridSelectCell"
></event>
<event
name=
"OnKeyDown"
></event>
<event
name=
"OnKeyDown"
>
onKeyDown
</event>
<event
name=
"OnKeyUp"
></event>
<event
name=
"OnKeyUp"
></event>
<event
name=
"OnKillFocus"
></event>
<event
name=
"OnKillFocus"
></event>
<event
name=
"OnLeaveWindow"
></event>
<event
name=
"OnLeaveWindow"
></event>
...
@@ -625,7 +625,7 @@
...
@@ -625,7 +625,7 @@
<event
name=
"OnGridRangeSelect"
></event>
<event
name=
"OnGridRangeSelect"
></event>
<event
name=
"OnGridRowSize"
></event>
<event
name=
"OnGridRowSize"
></event>
<event
name=
"OnGridSelectCell"
></event>
<event
name=
"OnGridSelectCell"
></event>
<event
name=
"OnKeyDown"
></event>
<event
name=
"OnKeyDown"
>
onKeyDown
</event>
<event
name=
"OnKeyUp"
></event>
<event
name=
"OnKeyUp"
></event>
<event
name=
"OnKillFocus"
></event>
<event
name=
"OnKillFocus"
></event>
<event
name=
"OnLeaveWindow"
></event>
<event
name=
"OnLeaveWindow"
></event>
...
@@ -1105,11 +1105,11 @@
...
@@ -1105,11 +1105,11 @@
</object>
</object>
</object>
</object>
</object>
</object>
<object
class=
"sizeritem"
expanded=
"
1
"
>
<object
class=
"sizeritem"
expanded=
"
0
"
>
<property
name=
"border"
>
5
</property>
<property
name=
"border"
>
5
</property>
<property
name=
"flag"
>
wxALL|wxEXPAND
</property>
<property
name=
"flag"
>
wxALL|wxEXPAND
</property>
<property
name=
"proportion"
>
0
</property>
<property
name=
"proportion"
>
0
</property>
<object
class=
"wxStaticBoxSizer"
expanded=
"
1
"
>
<object
class=
"wxStaticBoxSizer"
expanded=
"
0
"
>
<property
name=
"id"
>
wxID_ANY
</property>
<property
name=
"id"
>
wxID_ANY
</property>
<property
name=
"label"
>
Path Substitutions
</property>
<property
name=
"label"
>
Path Substitutions
</property>
<property
name=
"minimum_size"
></property>
<property
name=
"minimum_size"
></property>
...
@@ -1262,11 +1262,11 @@
...
@@ -1262,11 +1262,11 @@
</object>
</object>
</object>
</object>
</object>
</object>
<object
class=
"sizeritem"
expanded=
"
1
"
>
<object
class=
"sizeritem"
expanded=
"
0
"
>
<property
name=
"border"
>
5
</property>
<property
name=
"border"
>
5
</property>
<property
name=
"flag"
>
wxEXPAND
</property>
<property
name=
"flag"
>
wxEXPAND
</property>
<property
name=
"proportion"
>
0
</property>
<property
name=
"proportion"
>
0
</property>
<object
class=
"wxBoxSizer"
expanded=
"
1
"
>
<object
class=
"wxBoxSizer"
expanded=
"
0
"
>
<property
name=
"minimum_size"
></property>
<property
name=
"minimum_size"
></property>
<property
name=
"name"
>
m_bottom_sizer
</property>
<property
name=
"name"
>
m_bottom_sizer
</property>
<property
name=
"orient"
>
wxVERTICAL
</property>
<property
name=
"orient"
>
wxVERTICAL
</property>
...
...
pcbnew/dialogs/dialog_fp_lib_table_base.h
View file @
e0a0f596
...
@@ -57,7 +57,7 @@ class DIALOG_FP_LIB_TABLE_BASE : public DIALOG_SHIM
...
@@ -57,7 +57,7 @@ class DIALOG_FP_LIB_TABLE_BASE : public DIALOG_SHIM
wxButton
*
m_sdbSizer1Cancel
;
wxButton
*
m_sdbSizer1Cancel
;
// Virtual event handlers, overide them in your derived class
// Virtual event handlers, overide them in your derived class
virtual
void
on
InitDialog
(
wxInitDialog
Event
&
event
)
{
event
.
Skip
();
}
virtual
void
on
KeyDown
(
wxKey
Event
&
event
)
{
event
.
Skip
();
}
virtual
void
pageChangedHandler
(
wxAuiNotebookEvent
&
event
)
{
event
.
Skip
();
}
virtual
void
pageChangedHandler
(
wxAuiNotebookEvent
&
event
)
{
event
.
Skip
();
}
virtual
void
onGridCellLeftClick
(
wxGridEvent
&
event
)
{
event
.
Skip
();
}
virtual
void
onGridCellLeftClick
(
wxGridEvent
&
event
)
{
event
.
Skip
();
}
virtual
void
onGridCellLeftDClick
(
wxGridEvent
&
event
)
{
event
.
Skip
();
}
virtual
void
onGridCellLeftDClick
(
wxGridEvent
&
event
)
{
event
.
Skip
();
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment