Overhaul Symbol Library References dialog.
Fixes some layout issues and standardizes the action buttons. Also works around a wxWidgets bug in row sizing. (cherry picked from commit 7abc922)
This commit is contained in:
parent
41829162d2
commit
420c2020fb
|
@ -29,20 +29,229 @@
|
||||||
|
|
||||||
|
|
||||||
#include <fctsys.h>
|
#include <fctsys.h>
|
||||||
#include <dialog_edit_components_libid_base.h>
|
|
||||||
#include <sch_edit_frame.h>
|
#include <sch_edit_frame.h>
|
||||||
#include <class_drawpanel.h>
|
#include <class_drawpanel.h>
|
||||||
#include <sch_component.h>
|
#include <sch_component.h>
|
||||||
#include <sch_reference_list.h>
|
#include <sch_reference_list.h>
|
||||||
#include <pgm_base.h>
|
#include <pgm_base.h>
|
||||||
#include <symbol_lib_table.h>
|
#include <symbol_lib_table.h>
|
||||||
|
#include <widgets/wx_grid.h>
|
||||||
|
|
||||||
#include <wx/choicdlg.h>
|
#include <dialog_edit_components_libid_base.h>
|
||||||
|
#include <wx/tokenzr.h>
|
||||||
|
|
||||||
#define COL_REFS 0
|
#define COL_REFS 0
|
||||||
#define COL_CURR_LIBID 1
|
#define COL_CURR_LIBID 1
|
||||||
#define COL_NEW_LIBID 2
|
#define COL_NEW_LIBID 2
|
||||||
|
|
||||||
|
// a re-implementation of wxGridCellAutoWrapStringRenderer to allow workaround to autorowsize bug
|
||||||
|
class GRIDCELL_AUTOWRAP_STRINGRENDERER : public wxGridCellAutoWrapStringRenderer
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
int GetHeight( wxDC& aDC, wxGrid* aGrid, int aRow, int aCol );
|
||||||
|
|
||||||
|
wxGridCellRenderer *Clone() const override
|
||||||
|
{ return new GRIDCELL_AUTOWRAP_STRINGRENDERER; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
// HELPER ROUTINES UNCHANGED FROM wxWidgets IMPLEMENTATION
|
||||||
|
|
||||||
|
wxArrayString GetTextLines( wxGrid& grid,
|
||||||
|
wxDC& dc,
|
||||||
|
const wxGridCellAttr& attr,
|
||||||
|
const wxRect& rect,
|
||||||
|
int row, int col);
|
||||||
|
|
||||||
|
// Helper methods of GetTextLines()
|
||||||
|
|
||||||
|
// Break a single logical line of text into several physical lines, all of
|
||||||
|
// which are added to the lines array. The lines are broken at maxWidth and
|
||||||
|
// the dc is used for measuring text extent only.
|
||||||
|
void BreakLine(wxDC& dc,
|
||||||
|
const wxString& logicalLine,
|
||||||
|
wxCoord maxWidth,
|
||||||
|
wxArrayString& lines);
|
||||||
|
|
||||||
|
// Break a word, which is supposed to be wider than maxWidth, into several
|
||||||
|
// lines, which are added to lines array and the last, incomplete, of which
|
||||||
|
// is returned in line output parameter.
|
||||||
|
//
|
||||||
|
// Returns the width of the last line.
|
||||||
|
wxCoord BreakWord(wxDC& dc,
|
||||||
|
const wxString& word,
|
||||||
|
wxCoord maxWidth,
|
||||||
|
wxArrayString& lines,
|
||||||
|
wxString& line);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// PRIVATE METHOD UNCHANGED FROM wxWidgets IMPLEMENTATION
|
||||||
|
wxArrayString
|
||||||
|
GRIDCELL_AUTOWRAP_STRINGRENDERER::GetTextLines(wxGrid& grid,
|
||||||
|
wxDC& dc,
|
||||||
|
const wxGridCellAttr& attr,
|
||||||
|
const wxRect& rect,
|
||||||
|
int row, int col)
|
||||||
|
{
|
||||||
|
dc.SetFont(attr.GetFont());
|
||||||
|
const wxCoord maxWidth = rect.GetWidth();
|
||||||
|
|
||||||
|
// Transform logical lines into physical ones, wrapping the longer ones.
|
||||||
|
const wxArrayString
|
||||||
|
logicalLines = wxSplit(grid.GetCellValue(row, col), '\n', '\0');
|
||||||
|
|
||||||
|
// Trying to do anything if the column is hidden anyhow doesn't make sense
|
||||||
|
// and we run into problems in BreakLine() in this case.
|
||||||
|
if ( maxWidth <= 0 )
|
||||||
|
return logicalLines;
|
||||||
|
|
||||||
|
wxArrayString physicalLines;
|
||||||
|
for ( wxArrayString::const_iterator it = logicalLines.begin();
|
||||||
|
it != logicalLines.end();
|
||||||
|
++it )
|
||||||
|
{
|
||||||
|
const wxString& line = *it;
|
||||||
|
|
||||||
|
if ( dc.GetTextExtent(line).x > maxWidth )
|
||||||
|
{
|
||||||
|
// Line does not fit, break it up.
|
||||||
|
BreakLine(dc, line, maxWidth, physicalLines);
|
||||||
|
}
|
||||||
|
else // The entire line fits as is
|
||||||
|
{
|
||||||
|
physicalLines.push_back(line);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return physicalLines;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// PRIVATE METHOD UNCHANGED FROM wxWidgets IMPLEMENTATION
|
||||||
|
void
|
||||||
|
GRIDCELL_AUTOWRAP_STRINGRENDERER::BreakLine(wxDC& dc,
|
||||||
|
const wxString& logicalLine,
|
||||||
|
wxCoord maxWidth,
|
||||||
|
wxArrayString& lines)
|
||||||
|
{
|
||||||
|
wxCoord lineWidth = 0;
|
||||||
|
wxString line;
|
||||||
|
|
||||||
|
// For each word
|
||||||
|
wxStringTokenizer wordTokenizer(logicalLine, wxS(" \t"), wxTOKEN_RET_DELIMS);
|
||||||
|
while ( wordTokenizer.HasMoreTokens() )
|
||||||
|
{
|
||||||
|
const wxString word = wordTokenizer.GetNextToken();
|
||||||
|
const wxCoord wordWidth = dc.GetTextExtent(word).x;
|
||||||
|
if ( lineWidth + wordWidth < maxWidth )
|
||||||
|
{
|
||||||
|
// Word fits, just add it to this line.
|
||||||
|
line += word;
|
||||||
|
lineWidth += wordWidth;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Word does not fit, check whether the word is itself wider that
|
||||||
|
// available width
|
||||||
|
if ( wordWidth < maxWidth )
|
||||||
|
{
|
||||||
|
// Word can fit in a new line, put it at the beginning
|
||||||
|
// of the new line.
|
||||||
|
lines.push_back(line);
|
||||||
|
line = word;
|
||||||
|
lineWidth = wordWidth;
|
||||||
|
}
|
||||||
|
else // Word cannot fit in available width at all.
|
||||||
|
{
|
||||||
|
if ( !line.empty() )
|
||||||
|
{
|
||||||
|
lines.push_back(line);
|
||||||
|
line.clear();
|
||||||
|
lineWidth = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Break it up in several lines.
|
||||||
|
lineWidth = BreakWord(dc, word, maxWidth, lines, line);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !line.empty() )
|
||||||
|
lines.push_back(line);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// PRIVATE METHOD UNCHANGED FROM wxWidgets IMPLEMENTATION
|
||||||
|
wxCoord
|
||||||
|
GRIDCELL_AUTOWRAP_STRINGRENDERER::BreakWord(wxDC& dc,
|
||||||
|
const wxString& word,
|
||||||
|
wxCoord maxWidth,
|
||||||
|
wxArrayString& lines,
|
||||||
|
wxString& line)
|
||||||
|
{
|
||||||
|
wxArrayInt widths;
|
||||||
|
dc.GetPartialTextExtents(word, widths);
|
||||||
|
|
||||||
|
// TODO: Use binary search to find the first element > maxWidth.
|
||||||
|
const unsigned count = widths.size();
|
||||||
|
unsigned n;
|
||||||
|
for ( n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
if ( widths[n] > maxWidth )
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( n == 0 )
|
||||||
|
{
|
||||||
|
// This is a degenerate case: the first character of the word is
|
||||||
|
// already wider than the available space, so we just can't show it
|
||||||
|
// completely and have to put the first character in this line.
|
||||||
|
n = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
lines.push_back(word.substr(0, n));
|
||||||
|
|
||||||
|
// Check if the remainder of the string fits in one line.
|
||||||
|
//
|
||||||
|
// Unfortunately we can't use the existing partial text extents as the
|
||||||
|
// extent of the remainder may be different when it's rendered in a
|
||||||
|
// separate line instead of as part of the same one, so we have to
|
||||||
|
// recompute it.
|
||||||
|
const wxString rest = word.substr(n);
|
||||||
|
const wxCoord restWidth = dc.GetTextExtent(rest).x;
|
||||||
|
if ( restWidth <= maxWidth )
|
||||||
|
{
|
||||||
|
line = rest;
|
||||||
|
return restWidth;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Break the rest of the word into lines.
|
||||||
|
//
|
||||||
|
// TODO: Perhaps avoid recursion? The code is simpler like this but using a
|
||||||
|
// loop in this function would probably be more efficient.
|
||||||
|
return BreakWord(dc, rest, maxWidth, lines, line);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#define GRID_CELL_MARGIN 3
|
||||||
|
|
||||||
|
int GRIDCELL_AUTOWRAP_STRINGRENDERER::GetHeight( wxDC& aDC, wxGrid* aGrid, int aRow, int aCol )
|
||||||
|
{
|
||||||
|
wxGridCellAttr* attr = aGrid->GetOrCreateCellAttr( aRow, aCol );
|
||||||
|
wxRect rect;
|
||||||
|
|
||||||
|
aDC.SetFont( attr->GetFont() );
|
||||||
|
rect.SetWidth( aGrid->GetColSize( aCol ) - ( 2 * GRID_CELL_MARGIN ) );
|
||||||
|
|
||||||
|
const size_t numLines = GetTextLines( *aGrid, aDC, *attr, rect, aRow, aCol ).size();
|
||||||
|
const int textHeight = numLines *aDC.GetCharHeight();
|
||||||
|
|
||||||
|
attr->DecRef();
|
||||||
|
|
||||||
|
return textHeight + ( 2 * GRID_CELL_MARGIN );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// a helper class to handle components to edit
|
// a helper class to handle components to edit
|
||||||
class CMP_CANDIDATE
|
class CMP_CANDIDATE
|
||||||
{
|
{
|
||||||
|
@ -89,6 +298,7 @@ class DIALOG_EDIT_COMPONENTS_LIBID : public DIALOG_EDIT_COMPONENTS_LIBID_BASE
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
DIALOG_EDIT_COMPONENTS_LIBID( SCH_EDIT_FRAME* aParent );
|
DIALOG_EDIT_COMPONENTS_LIBID( SCH_EDIT_FRAME* aParent );
|
||||||
|
~DIALOG_EDIT_COMPONENTS_LIBID() override;
|
||||||
|
|
||||||
bool IsSchematicModified() { return m_isModified; }
|
bool IsSchematicModified() { return m_isModified; }
|
||||||
|
|
||||||
|
@ -99,17 +309,17 @@ private:
|
||||||
|
|
||||||
std::vector<CMP_CANDIDATE> m_components;
|
std::vector<CMP_CANDIDATE> m_components;
|
||||||
|
|
||||||
|
GRIDCELL_AUTOWRAP_STRINGRENDERER* m_autoWrapRenderer;
|
||||||
|
|
||||||
void initDlg();
|
void initDlg();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a new row (new entry) in m_grid.
|
* Add a new row (new entry) in m_grid.
|
||||||
* @param aRowId is the row index
|
|
||||||
* @param aMarkRow = true to use bold/italic font in column COL_CURR_LIBID
|
* @param aMarkRow = true to use bold/italic font in column COL_CURR_LIBID
|
||||||
* @param aReferences is the value of cell( aRowId, COL_REFS)
|
* @param aReferences is the value of cell( aRowId, COL_REFS)
|
||||||
* @param aStrLibId is the value of cell( aRowId, COL_CURR_LIBID)
|
* @param aStrLibId is the value of cell( aRowId, COL_CURR_LIBID)
|
||||||
*/
|
*/
|
||||||
void AddRowToGrid( int aRowId, bool aMarkRow,
|
void AddRowToGrid( bool aMarkRow, const wxString& aReferences, const wxString& aStrLibId );
|
||||||
const wxString& aReferences, const wxString& aStrLibId );
|
|
||||||
|
|
||||||
/// returns true if all new lib id are valid
|
/// returns true if all new lib id are valid
|
||||||
bool validateLibIds();
|
bool validateLibIds();
|
||||||
|
@ -139,8 +349,6 @@ private:
|
||||||
event.Skip();
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
void onButtonBrowseLibraries( wxCommandEvent& event ) override;
|
|
||||||
|
|
||||||
// Undo all changes, and clear the list of new lib_ids
|
// Undo all changes, and clear the list of new lib_ids
|
||||||
void onUndoChangesButton( wxCommandEvent& event ) override;
|
void onUndoChangesButton( wxCommandEvent& event ) override;
|
||||||
|
|
||||||
|
@ -153,14 +361,12 @@ private:
|
||||||
m_buttonUndo->Enable( m_isModified );
|
m_buttonUndo->Enable( m_isModified );
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateUIBrowseButton( wxUpdateUIEvent& event ) override
|
|
||||||
{
|
|
||||||
wxArrayInt rows = m_grid->GetSelectedRows();
|
|
||||||
m_buttonBrowseLibs->Enable( rows.GetCount() == 1 );
|
|
||||||
}
|
|
||||||
|
|
||||||
// Automatically called when click on OK button
|
// Automatically called when click on OK button
|
||||||
bool TransferDataFromWindow() override;
|
bool TransferDataFromWindow() override;
|
||||||
|
|
||||||
|
void AdjustGridColumns( int aWidth );
|
||||||
|
|
||||||
|
void OnSizeGrid( wxSizeEvent& event ) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -168,22 +374,21 @@ DIALOG_EDIT_COMPONENTS_LIBID::DIALOG_EDIT_COMPONENTS_LIBID( SCH_EDIT_FRAME* aPar
|
||||||
:DIALOG_EDIT_COMPONENTS_LIBID_BASE( aParent )
|
:DIALOG_EDIT_COMPONENTS_LIBID_BASE( aParent )
|
||||||
{
|
{
|
||||||
m_parent = aParent;
|
m_parent = aParent;
|
||||||
|
m_autoWrapRenderer = new GRIDCELL_AUTOWRAP_STRINGRENDERER;
|
||||||
|
|
||||||
initDlg();
|
initDlg();
|
||||||
|
|
||||||
// Gives a min size to display m_grid, now it is populated:
|
FinishDialogSettings();
|
||||||
int minwidth = 30 // a margin
|
|
||||||
+ m_grid->GetRowLabelSize() + m_grid->GetColSize( COL_REFS )
|
|
||||||
+ m_grid->GetColSize( COL_CURR_LIBID ) + m_grid->GetColSize( COL_NEW_LIBID );
|
|
||||||
|
|
||||||
SetMinClientSize( wxSize( minwidth, VertPixelsFromDU( 250 ) ) );
|
|
||||||
|
|
||||||
SetSizeInDU( 500, 400 );
|
|
||||||
Center();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// A sort compare function to sort components list by LIB_ID
|
DIALOG_EDIT_COMPONENTS_LIBID::~DIALOG_EDIT_COMPONENTS_LIBID()
|
||||||
// inside the group of same LIB_ID, sort by reference
|
{
|
||||||
|
m_autoWrapRenderer->DecRef();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// A sort compare function to sort components list by LIB_ID and then reference
|
||||||
static bool sort_by_libid( const CMP_CANDIDATE& cmp1, const CMP_CANDIDATE& cmp2 )
|
static bool sort_by_libid( const CMP_CANDIDATE& cmp1, const CMP_CANDIDATE& cmp2 )
|
||||||
{
|
{
|
||||||
if( cmp1.m_Component->GetLibId() == cmp2.m_Component->GetLibId() )
|
if( cmp1.m_Component->GetLibId() == cmp2.m_Component->GetLibId() )
|
||||||
|
@ -195,6 +400,9 @@ static bool sort_by_libid( const CMP_CANDIDATE& cmp1, const CMP_CANDIDATE& cmp2
|
||||||
|
|
||||||
void DIALOG_EDIT_COMPONENTS_LIBID::initDlg()
|
void DIALOG_EDIT_COMPONENTS_LIBID::initDlg()
|
||||||
{
|
{
|
||||||
|
// Clear the FormBuilder rows
|
||||||
|
m_grid->DeleteRows( 0, m_grid->GetNumberRows() );
|
||||||
|
|
||||||
m_isModified = false;
|
m_isModified = false;
|
||||||
|
|
||||||
// Build the component list:
|
// Build the component list:
|
||||||
|
@ -276,7 +484,7 @@ void DIALOG_EDIT_COMPONENTS_LIBID::initDlg()
|
||||||
if( last_str_libid != str_libid )
|
if( last_str_libid != str_libid )
|
||||||
{
|
{
|
||||||
// Add last group to grid
|
// Add last group to grid
|
||||||
AddRowToGrid( row, mark_cell, refs, last_str_libid );
|
AddRowToGrid( mark_cell, refs, last_str_libid );
|
||||||
|
|
||||||
// prepare next entry
|
// prepare next entry
|
||||||
mark_cell = cmp->m_IsOrphan;
|
mark_cell = cmp->m_IsOrphan;
|
||||||
|
@ -286,26 +494,14 @@ void DIALOG_EDIT_COMPONENTS_LIBID::initDlg()
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !refs.IsEmpty() )
|
if( !refs.IsEmpty() )
|
||||||
refs += " ";
|
refs += wxT( ", " );
|
||||||
|
|
||||||
refs += cmp->GetSchematicReference();
|
refs += cmp->GetSchematicReference();
|
||||||
cmp->m_Row = row;
|
cmp->m_Row = row;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add last component group:
|
// Add last component group:
|
||||||
AddRowToGrid( row, mark_cell, refs, last_str_libid );
|
AddRowToGrid( mark_cell, refs, last_str_libid );
|
||||||
|
|
||||||
m_grid->AutoSizeColumn( COL_CURR_LIBID );
|
|
||||||
// ensure the column title is correctly displayed
|
|
||||||
// (the min size is already fixed by AutoSizeColumn() )
|
|
||||||
m_grid->AutoSizeColLabelSize( COL_CURR_LIBID );
|
|
||||||
|
|
||||||
// Gives a similar width to COL_NEW_LIBID because it can contains similar strings
|
|
||||||
if( m_grid->GetColSize( COL_CURR_LIBID ) > m_grid->GetColSize( COL_NEW_LIBID ) )
|
|
||||||
m_grid->SetColSize( COL_NEW_LIBID, m_grid->GetColSize( COL_CURR_LIBID ) );
|
|
||||||
// ensure the column title is correctly displayed
|
|
||||||
m_grid->SetColMinimalWidth( COL_NEW_LIBID, m_grid->GetColSize( COL_NEW_LIBID ) );
|
|
||||||
m_grid->AutoSizeColLabelSize( COL_NEW_LIBID );
|
|
||||||
|
|
||||||
// Allows only the selection by row
|
// Allows only the selection by row
|
||||||
m_grid->SetSelectionMode( wxGrid::wxGridSelectRows );
|
m_grid->SetSelectionMode( wxGrid::wxGridSelectRows );
|
||||||
|
@ -315,16 +511,15 @@ void DIALOG_EDIT_COMPONENTS_LIBID::initDlg()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void DIALOG_EDIT_COMPONENTS_LIBID::AddRowToGrid( int aRowId, bool aMarkRow,
|
void DIALOG_EDIT_COMPONENTS_LIBID::AddRowToGrid( bool aMarkRow, const wxString& aReferences,
|
||||||
const wxString& aReferences, const wxString& aStrLibId )
|
const wxString& aStrLibId )
|
||||||
{
|
{
|
||||||
|
int row = m_grid->GetNumberRows();
|
||||||
|
|
||||||
if( aMarkRow ) // a orphan component exists, set m_AsOrphanCmp as true
|
if( aMarkRow ) // a orphan component exists, set m_AsOrphanCmp as true
|
||||||
m_OrphansRowIndexes.push_back( aRowId );
|
m_OrphansRowIndexes.push_back( row );
|
||||||
|
|
||||||
int row = aRowId;
|
m_grid->AppendRows( 1 );
|
||||||
|
|
||||||
if( m_grid->GetNumberRows() <= row )
|
|
||||||
m_grid->AppendRows();
|
|
||||||
|
|
||||||
m_grid->SetCellValue( row, COL_REFS, aReferences );
|
m_grid->SetCellValue( row, COL_REFS, aReferences );
|
||||||
m_grid->SetReadOnly( row, COL_REFS );
|
m_grid->SetReadOnly( row, COL_REFS );
|
||||||
|
@ -340,13 +535,20 @@ void DIALOG_EDIT_COMPONENTS_LIBID::AddRowToGrid( int aRowId, bool aMarkRow,
|
||||||
m_grid->SetCellFont( row, COL_CURR_LIBID, font );
|
m_grid->SetCellFont( row, COL_CURR_LIBID, font );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_grid->SetCellRenderer( row, COL_REFS, new wxGridCellAutoWrapStringRenderer);
|
m_grid->SetCellRenderer( row, COL_REFS, m_autoWrapRenderer->Clone() );
|
||||||
m_grid->AutoSizeRow( row, false );
|
|
||||||
|
// wxWidgets' AutoRowHeight fails when used with wxGridCellAutoWrapStringRenderer
|
||||||
|
// (fixed in 2014, but didn't get in to wxWidgets 3.0.2)
|
||||||
|
wxClientDC dc( this );
|
||||||
|
m_grid->SetRowSize( row, m_autoWrapRenderer->GetHeight( dc, m_grid, row, COL_REFS ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool DIALOG_EDIT_COMPONENTS_LIBID::validateLibIds()
|
bool DIALOG_EDIT_COMPONENTS_LIBID::validateLibIds()
|
||||||
{
|
{
|
||||||
|
// Commit any pending edits
|
||||||
|
m_grid->DisableCellEditControl();
|
||||||
|
|
||||||
int row_max = m_grid->GetNumberRows() - 1;
|
int row_max = m_grid->GetNumberRows() - 1;
|
||||||
|
|
||||||
for( int row = 0; row <= row_max; row++ )
|
for( int row = 0; row <= row_max; row++ )
|
||||||
|
@ -363,8 +565,16 @@ bool DIALOG_EDIT_COMPONENTS_LIBID::validateLibIds()
|
||||||
if( !id.IsValid() )
|
if( !id.IsValid() )
|
||||||
{
|
{
|
||||||
wxString msg;
|
wxString msg;
|
||||||
msg.Printf( _( "Symbol library identifier \"%s\" is not valid at row %d!" ), new_libid, row+1 );
|
msg.Printf( _( "Symbol library identifier \"%s\" is not valid." ), new_libid );
|
||||||
wxMessageBox( msg );
|
wxMessageBox( msg );
|
||||||
|
|
||||||
|
m_grid->SetFocus();
|
||||||
|
m_grid->MakeCellVisible( row, COL_NEW_LIBID );
|
||||||
|
m_grid->SetGridCursor( row, COL_NEW_LIBID );
|
||||||
|
|
||||||
|
m_grid->EnableCellEditControl( true );
|
||||||
|
m_grid->ShowCellEditControl();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -405,17 +615,6 @@ void DIALOG_EDIT_COMPONENTS_LIBID::onCellBrowseLib( wxGridEvent& event )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void DIALOG_EDIT_COMPONENTS_LIBID::onButtonBrowseLibraries( wxCommandEvent& event )
|
|
||||||
{
|
|
||||||
wxArrayInt rows = m_grid->GetSelectedRows();
|
|
||||||
|
|
||||||
if( rows.GetCount() != 1 ) // Should not occur, because the button is disabled
|
|
||||||
return;
|
|
||||||
|
|
||||||
setLibIdByBrowser( rows[0] );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void DIALOG_EDIT_COMPONENTS_LIBID::onClickOrphansButton( wxCommandEvent& event )
|
void DIALOG_EDIT_COMPONENTS_LIBID::onClickOrphansButton( wxCommandEvent& event )
|
||||||
{
|
{
|
||||||
std::vector< wxString > libs = Prj().SchSymbolLibTable()->GetLogicalLibs();
|
std::vector< wxString > libs = Prj().SchSymbolLibTable()->GetLogicalLibs();
|
||||||
|
@ -611,6 +810,31 @@ void DIALOG_EDIT_COMPONENTS_LIBID::revertChanges()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void DIALOG_EDIT_COMPONENTS_LIBID::AdjustGridColumns( int aWidth )
|
||||||
|
{
|
||||||
|
// Account for scroll bars
|
||||||
|
aWidth -= ( m_grid->GetSize().x - m_grid->GetClientSize().x );
|
||||||
|
|
||||||
|
m_grid->SetColSize( 0, aWidth / 3 );
|
||||||
|
m_grid->SetColSize( 1, aWidth / 3 );
|
||||||
|
m_grid->SetColSize( 2, aWidth - m_grid->GetColSize( 0 ) - m_grid->GetColSize( 1 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void DIALOG_EDIT_COMPONENTS_LIBID::OnSizeGrid( wxSizeEvent& event )
|
||||||
|
{
|
||||||
|
AdjustGridColumns( event.GetSize().GetX() );
|
||||||
|
|
||||||
|
wxClientDC dc( this );
|
||||||
|
|
||||||
|
// wxWidgets' AutoRowHeight fails when used with wxGridCellAutoWrapStringRenderer
|
||||||
|
for( int row = 0; row < m_grid->GetNumberRows(); ++row )
|
||||||
|
m_grid->SetRowSize( row, m_autoWrapRenderer->GetHeight( dc, m_grid, row, COL_REFS ) );
|
||||||
|
|
||||||
|
event.Skip();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool InvokeDialogEditComponentsLibId( SCH_EDIT_FRAME* aCaller )
|
bool InvokeDialogEditComponentsLibId( SCH_EDIT_FRAME* aCaller )
|
||||||
{
|
{
|
||||||
// This dialog itself subsequently can invoke a KIWAY_PLAYER as a quasimodal
|
// This dialog itself subsequently can invoke a KIWAY_PLAYER as a quasimodal
|
||||||
|
|
|
@ -5,6 +5,8 @@
|
||||||
// PLEASE DO *NOT* EDIT THIS FILE!
|
// PLEASE DO *NOT* EDIT THIS FILE!
|
||||||
///////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#include "widgets/wx_grid.h"
|
||||||
|
|
||||||
#include "dialog_edit_components_libid_base.h"
|
#include "dialog_edit_components_libid_base.h"
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -16,11 +18,7 @@ DIALOG_EDIT_COMPONENTS_LIBID_BASE::DIALOG_EDIT_COMPONENTS_LIBID_BASE( wxWindow*
|
||||||
wxBoxSizer* bSizerMain;
|
wxBoxSizer* bSizerMain;
|
||||||
bSizerMain = new wxBoxSizer( wxVERTICAL );
|
bSizerMain = new wxBoxSizer( wxVERTICAL );
|
||||||
|
|
||||||
m_panelGrid = new wxPanel( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL );
|
m_grid = new WX_GRID( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 );
|
||||||
wxBoxSizer* bSizerGrid;
|
|
||||||
bSizerGrid = new wxBoxSizer( wxVERTICAL );
|
|
||||||
|
|
||||||
m_grid = new wxGrid( m_panelGrid, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0 );
|
|
||||||
|
|
||||||
// Grid
|
// Grid
|
||||||
m_grid->CreateGrid( 5, 3 );
|
m_grid->CreateGrid( 5, 3 );
|
||||||
|
@ -30,55 +28,56 @@ DIALOG_EDIT_COMPONENTS_LIBID_BASE::DIALOG_EDIT_COMPONENTS_LIBID_BASE( wxWindow*
|
||||||
m_grid->SetMargins( 0, 0 );
|
m_grid->SetMargins( 0, 0 );
|
||||||
|
|
||||||
// Columns
|
// Columns
|
||||||
m_grid->SetColSize( 0, 300 );
|
m_grid->SetColSize( 0, 280 );
|
||||||
m_grid->SetColSize( 1, 200 );
|
m_grid->SetColSize( 1, 280 );
|
||||||
m_grid->SetColSize( 2, 200 );
|
m_grid->SetColSize( 2, 280 );
|
||||||
m_grid->EnableDragColMove( false );
|
m_grid->EnableDragColMove( false );
|
||||||
m_grid->EnableDragColSize( true );
|
m_grid->EnableDragColSize( true );
|
||||||
m_grid->SetColLabelSize( 30 );
|
m_grid->SetColLabelSize( 22 );
|
||||||
m_grid->SetColLabelValue( 0, _("Symbols") );
|
m_grid->SetColLabelValue( 0, _("Symbols") );
|
||||||
m_grid->SetColLabelValue( 1, _("Current Library Reference") );
|
m_grid->SetColLabelValue( 1, _("Current Library Reference") );
|
||||||
m_grid->SetColLabelValue( 2, _("New Library Reference") );
|
m_grid->SetColLabelValue( 2, _("New Library Reference") );
|
||||||
m_grid->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
|
m_grid->SetColLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
|
||||||
|
|
||||||
// Rows
|
// Rows
|
||||||
m_grid->AutoSizeRows();
|
m_grid->EnableDragRowSize( false );
|
||||||
m_grid->EnableDragRowSize( true );
|
m_grid->SetRowLabelSize( 0 );
|
||||||
m_grid->SetRowLabelSize( 30 );
|
|
||||||
m_grid->SetRowLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
|
m_grid->SetRowLabelAlignment( wxALIGN_CENTRE, wxALIGN_CENTRE );
|
||||||
|
|
||||||
// Label Appearance
|
// Label Appearance
|
||||||
|
|
||||||
// Cell Defaults
|
// Cell Defaults
|
||||||
m_grid->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
|
m_grid->SetDefaultCellAlignment( wxALIGN_LEFT, wxALIGN_TOP );
|
||||||
m_grid->SetMinSize( wxSize( 700,-1 ) );
|
m_grid->SetMinSize( wxSize( -1,300 ) );
|
||||||
|
|
||||||
bSizerGrid->Add( m_grid, 1, wxALL|wxEXPAND, 5 );
|
bSizerMain->Add( m_grid, 1, wxEXPAND|wxTOP|wxRIGHT|wxLEFT, 10 );
|
||||||
|
|
||||||
|
|
||||||
m_panelGrid->SetSizer( bSizerGrid );
|
|
||||||
m_panelGrid->Layout();
|
|
||||||
bSizerGrid->Fit( m_panelGrid );
|
|
||||||
bSizerMain->Add( m_panelGrid, 1, wxEXPAND | wxALL, 5 );
|
|
||||||
|
|
||||||
m_staticline = new wxStaticLine( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLI_HORIZONTAL );
|
|
||||||
bSizerMain->Add( m_staticline, 0, wxEXPAND | wxALL, 5 );
|
|
||||||
|
|
||||||
wxBoxSizer* bSizerMsgWarning;
|
wxBoxSizer* bSizerMsgWarning;
|
||||||
bSizerMsgWarning = new wxBoxSizer( wxVERTICAL );
|
bSizerMsgWarning = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
m_staticTextWarning = new wxStaticText( this, wxID_ANY, _("Warning: Changes made from this dialog cannot be undone, after closing it."), wxDefaultPosition, wxDefaultSize, 0 );
|
m_staticTextWarning = new wxStaticText( this, wxID_ANY, _("Warning: changes made from this dialog cannot be undone after closing it."), wxDefaultPosition, wxDefaultSize, 0 );
|
||||||
m_staticTextWarning->Wrap( -1 );
|
m_staticTextWarning->Wrap( -1 );
|
||||||
m_staticTextWarning->SetFont( wxFont( wxNORMAL_FONT->GetPointSize(), wxFONTFAMILY_DEFAULT, wxFONTSTYLE_NORMAL, wxFONTWEIGHT_BOLD, false, wxEmptyString ) );
|
m_staticTextWarning->SetFont( wxFont( wxNORMAL_FONT->GetPointSize(), wxFONTFAMILY_DEFAULT, wxFONTSTYLE_NORMAL, wxFONTWEIGHT_BOLD, false, wxEmptyString ) );
|
||||||
|
|
||||||
bSizerMsgWarning->Add( m_staticTextWarning, 0, wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL, 5 );
|
bSizerMsgWarning->Add( m_staticTextWarning, 1, wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxRIGHT, 5 );
|
||||||
|
|
||||||
|
m_buttonUndo = new wxButton( this, wxID_ANY, _("Undo Changes"), wxDefaultPosition, wxDefaultSize, 0 );
|
||||||
|
bSizerMsgWarning->Add( m_buttonUndo, 0, wxALIGN_CENTER_VERTICAL|wxALL, 5 );
|
||||||
|
|
||||||
|
|
||||||
bSizerMain->Add( bSizerMsgWarning, 0, wxALIGN_CENTER_VERTICAL|wxALIGN_CENTER_HORIZONTAL, 5 );
|
bSizerMain->Add( bSizerMsgWarning, 0, wxALIGN_CENTER_VERTICAL|wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxALL, 10 );
|
||||||
|
|
||||||
|
m_staticline2 = new wxStaticLine( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLI_HORIZONTAL );
|
||||||
|
bSizerMain->Add( m_staticline2, 0, wxEXPAND|wxRIGHT|wxLEFT, 5 );
|
||||||
|
|
||||||
wxBoxSizer* bSizerButtons;
|
wxBoxSizer* bSizerButtons;
|
||||||
bSizerButtons = new wxBoxSizer( wxHORIZONTAL );
|
bSizerButtons = new wxBoxSizer( wxHORIZONTAL );
|
||||||
|
|
||||||
|
m_buttonOrphanItems = new wxButton( this, wxID_ANY, _("Map Orphans"), wxDefaultPosition, wxDefaultSize, 0 );
|
||||||
|
m_buttonOrphanItems->SetToolTip( _("If some components are orphan (the linked symbol is found nowhere),\ntry to find a candidate having the same name in one of loaded symbol libraries") );
|
||||||
|
|
||||||
|
bSizerButtons->Add( m_buttonOrphanItems, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 );
|
||||||
|
|
||||||
m_sdbSizer = new wxStdDialogButtonSizer();
|
m_sdbSizer = new wxStdDialogButtonSizer();
|
||||||
m_sdbSizerOK = new wxButton( this, wxID_OK );
|
m_sdbSizerOK = new wxButton( this, wxID_OK );
|
||||||
m_sdbSizer->AddButton( m_sdbSizerOK );
|
m_sdbSizer->AddButton( m_sdbSizerOK );
|
||||||
|
@ -88,21 +87,10 @@ DIALOG_EDIT_COMPONENTS_LIBID_BASE::DIALOG_EDIT_COMPONENTS_LIBID_BASE( wxWindow*
|
||||||
m_sdbSizer->AddButton( m_sdbSizerCancel );
|
m_sdbSizer->AddButton( m_sdbSizerCancel );
|
||||||
m_sdbSizer->Realize();
|
m_sdbSizer->Realize();
|
||||||
|
|
||||||
bSizerButtons->Add( m_sdbSizer, 0, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxALL, 5 );
|
bSizerButtons->Add( m_sdbSizer, 1, wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxALL, 5 );
|
||||||
|
|
||||||
m_buttonUndo = new wxButton( this, wxID_ANY, _("Undo Changes"), wxDefaultPosition, wxDefaultSize, 0 );
|
|
||||||
bSizerButtons->Add( m_buttonUndo, 0, wxTOP|wxBOTTOM|wxRIGHT|wxALIGN_CENTER_VERTICAL, 5 );
|
|
||||||
|
|
||||||
m_buttonBrowseLibs = new wxButton( this, wxID_ANY, _("Browse Libraries"), wxDefaultPosition, wxDefaultSize, 0 );
|
|
||||||
bSizerButtons->Add( m_buttonBrowseLibs, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 );
|
|
||||||
|
|
||||||
m_buttonOrphanItems = new wxButton( this, wxID_ANY, _("Map Orphans"), wxDefaultPosition, wxDefaultSize, 0 );
|
|
||||||
m_buttonOrphanItems->SetToolTip( _("If some components are orphan (the linked symbol is found nowhere),\ntry to find a candidate having the same name in one of loaded symbol libraries") );
|
|
||||||
|
|
||||||
bSizerButtons->Add( m_buttonOrphanItems, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 );
|
|
||||||
|
|
||||||
|
|
||||||
bSizerMain->Add( bSizerButtons, 0, wxALIGN_RIGHT, 5 );
|
bSizerMain->Add( bSizerButtons, 0, wxALIGN_RIGHT|wxEXPAND|wxLEFT, 5 );
|
||||||
|
|
||||||
|
|
||||||
this->SetSizer( bSizerMain );
|
this->SetSizer( bSizerMain );
|
||||||
|
@ -114,15 +102,12 @@ DIALOG_EDIT_COMPONENTS_LIBID_BASE::DIALOG_EDIT_COMPONENTS_LIBID_BASE( wxWindow*
|
||||||
// Connect Events
|
// Connect Events
|
||||||
m_grid->Connect( wxEVT_GRID_CELL_LEFT_DCLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
m_grid->Connect( wxEVT_GRID_CELL_LEFT_DCLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
||||||
m_grid->Connect( wxEVT_GRID_CELL_RIGHT_CLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
m_grid->Connect( wxEVT_GRID_CELL_RIGHT_CLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
||||||
m_grid->Connect( wxEVT_GRID_LABEL_LEFT_DCLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
m_grid->Connect( wxEVT_SIZE, wxSizeEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::OnSizeGrid ), NULL, this );
|
||||||
m_grid->Connect( wxEVT_GRID_LABEL_RIGHT_CLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
|
||||||
m_sdbSizerApply->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onApplyButton ), NULL, this );
|
|
||||||
m_sdbSizerCancel->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCancel ), NULL, this );
|
|
||||||
m_buttonUndo->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onUndoChangesButton ), NULL, this );
|
m_buttonUndo->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onUndoChangesButton ), NULL, this );
|
||||||
m_buttonUndo->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::updateUIChangesButton ), NULL, this );
|
m_buttonUndo->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::updateUIChangesButton ), NULL, this );
|
||||||
m_buttonBrowseLibs->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onButtonBrowseLibraries ), NULL, this );
|
|
||||||
m_buttonBrowseLibs->Connect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::updateUIBrowseButton ), NULL, this );
|
|
||||||
m_buttonOrphanItems->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onClickOrphansButton ), NULL, this );
|
m_buttonOrphanItems->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onClickOrphansButton ), NULL, this );
|
||||||
|
m_sdbSizerApply->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onApplyButton ), NULL, this );
|
||||||
|
m_sdbSizerCancel->Connect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCancel ), NULL, this );
|
||||||
}
|
}
|
||||||
|
|
||||||
DIALOG_EDIT_COMPONENTS_LIBID_BASE::~DIALOG_EDIT_COMPONENTS_LIBID_BASE()
|
DIALOG_EDIT_COMPONENTS_LIBID_BASE::~DIALOG_EDIT_COMPONENTS_LIBID_BASE()
|
||||||
|
@ -130,14 +115,11 @@ DIALOG_EDIT_COMPONENTS_LIBID_BASE::~DIALOG_EDIT_COMPONENTS_LIBID_BASE()
|
||||||
// Disconnect Events
|
// Disconnect Events
|
||||||
m_grid->Disconnect( wxEVT_GRID_CELL_LEFT_DCLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
m_grid->Disconnect( wxEVT_GRID_CELL_LEFT_DCLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
||||||
m_grid->Disconnect( wxEVT_GRID_CELL_RIGHT_CLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
m_grid->Disconnect( wxEVT_GRID_CELL_RIGHT_CLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
||||||
m_grid->Disconnect( wxEVT_GRID_LABEL_LEFT_DCLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
m_grid->Disconnect( wxEVT_SIZE, wxSizeEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::OnSizeGrid ), NULL, this );
|
||||||
m_grid->Disconnect( wxEVT_GRID_LABEL_RIGHT_CLICK, wxGridEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCellBrowseLib ), NULL, this );
|
|
||||||
m_sdbSizerApply->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onApplyButton ), NULL, this );
|
|
||||||
m_sdbSizerCancel->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCancel ), NULL, this );
|
|
||||||
m_buttonUndo->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onUndoChangesButton ), NULL, this );
|
m_buttonUndo->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onUndoChangesButton ), NULL, this );
|
||||||
m_buttonUndo->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::updateUIChangesButton ), NULL, this );
|
m_buttonUndo->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::updateUIChangesButton ), NULL, this );
|
||||||
m_buttonBrowseLibs->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onButtonBrowseLibraries ), NULL, this );
|
|
||||||
m_buttonBrowseLibs->Disconnect( wxEVT_UPDATE_UI, wxUpdateUIEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::updateUIBrowseButton ), NULL, this );
|
|
||||||
m_buttonOrphanItems->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onClickOrphansButton ), NULL, this );
|
m_buttonOrphanItems->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onClickOrphansButton ), NULL, this );
|
||||||
|
m_sdbSizerApply->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onApplyButton ), NULL, this );
|
||||||
|
m_sdbSizerCancel->Disconnect( wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler( DIALOG_EDIT_COMPONENTS_LIBID_BASE::onCancel ), NULL, this );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,11 +93,11 @@
|
||||||
<property name="name">bSizerMain</property>
|
<property name="name">bSizerMain</property>
|
||||||
<property name="orient">wxVERTICAL</property>
|
<property name="orient">wxVERTICAL</property>
|
||||||
<property name="permission">none</property>
|
<property name="permission">none</property>
|
||||||
<object class="sizeritem" expanded="1">
|
<object class="sizeritem" expanded="0">
|
||||||
<property name="border">5</property>
|
<property name="border">10</property>
|
||||||
<property name="flag">wxEXPAND | wxALL</property>
|
<property name="flag">wxEXPAND|wxTOP|wxRIGHT|wxLEFT</property>
|
||||||
<property name="proportion">1</property>
|
<property name="proportion">1</property>
|
||||||
<object class="wxPanel" expanded="1">
|
<object class="wxGrid" expanded="0">
|
||||||
<property name="BottomDockable">1</property>
|
<property name="BottomDockable">1</property>
|
||||||
<property name="LeftDockable">1</property>
|
<property name="LeftDockable">1</property>
|
||||||
<property name="RightDockable">1</property>
|
<property name="RightDockable">1</property>
|
||||||
|
@ -106,33 +106,58 @@
|
||||||
<property name="aui_name"></property>
|
<property name="aui_name"></property>
|
||||||
<property name="aui_position"></property>
|
<property name="aui_position"></property>
|
||||||
<property name="aui_row"></property>
|
<property name="aui_row"></property>
|
||||||
|
<property name="autosize_cols">0</property>
|
||||||
|
<property name="autosize_rows">0</property>
|
||||||
<property name="best_size"></property>
|
<property name="best_size"></property>
|
||||||
<property name="bg"></property>
|
<property name="bg"></property>
|
||||||
<property name="caption"></property>
|
<property name="caption"></property>
|
||||||
<property name="caption_visible">1</property>
|
<property name="caption_visible">1</property>
|
||||||
|
<property name="cell_bg"></property>
|
||||||
|
<property name="cell_font"></property>
|
||||||
|
<property name="cell_horiz_alignment">wxALIGN_LEFT</property>
|
||||||
|
<property name="cell_text"></property>
|
||||||
|
<property name="cell_vert_alignment">wxALIGN_TOP</property>
|
||||||
<property name="center_pane">0</property>
|
<property name="center_pane">0</property>
|
||||||
<property name="close_button">1</property>
|
<property name="close_button">1</property>
|
||||||
|
<property name="col_label_horiz_alignment">wxALIGN_CENTRE</property>
|
||||||
|
<property name="col_label_size">22</property>
|
||||||
|
<property name="col_label_values">"Symbols" "Current Library Reference" "New Library Reference"</property>
|
||||||
|
<property name="col_label_vert_alignment">wxALIGN_CENTRE</property>
|
||||||
|
<property name="cols">3</property>
|
||||||
|
<property name="column_sizes">280,280,280</property>
|
||||||
<property name="context_help"></property>
|
<property name="context_help"></property>
|
||||||
<property name="context_menu">1</property>
|
<property name="context_menu">1</property>
|
||||||
<property name="default_pane">0</property>
|
<property name="default_pane">0</property>
|
||||||
<property name="dock">Dock</property>
|
<property name="dock">Dock</property>
|
||||||
<property name="dock_fixed">0</property>
|
<property name="dock_fixed">0</property>
|
||||||
<property name="docking">Left</property>
|
<property name="docking">Left</property>
|
||||||
|
<property name="drag_col_move">0</property>
|
||||||
|
<property name="drag_col_size">1</property>
|
||||||
|
<property name="drag_grid_size">0</property>
|
||||||
|
<property name="drag_row_size">0</property>
|
||||||
|
<property name="editing">1</property>
|
||||||
<property name="enabled">1</property>
|
<property name="enabled">1</property>
|
||||||
<property name="fg"></property>
|
<property name="fg"></property>
|
||||||
<property name="floatable">1</property>
|
<property name="floatable">1</property>
|
||||||
<property name="font"></property>
|
<property name="font"></property>
|
||||||
|
<property name="grid_line_color"></property>
|
||||||
|
<property name="grid_lines">1</property>
|
||||||
<property name="gripper">0</property>
|
<property name="gripper">0</property>
|
||||||
<property name="hidden">0</property>
|
<property name="hidden">0</property>
|
||||||
<property name="id">wxID_ANY</property>
|
<property name="id">wxID_ANY</property>
|
||||||
|
<property name="label_bg"></property>
|
||||||
|
<property name="label_font"></property>
|
||||||
|
<property name="label_text"></property>
|
||||||
|
<property name="margin_height">0</property>
|
||||||
|
<property name="margin_width">0</property>
|
||||||
<property name="max_size"></property>
|
<property name="max_size"></property>
|
||||||
<property name="maximize_button">0</property>
|
<property name="maximize_button">0</property>
|
||||||
<property name="maximum_size"></property>
|
<property name="maximum_size"></property>
|
||||||
<property name="min_size"></property>
|
<property name="min_size"></property>
|
||||||
<property name="minimize_button">0</property>
|
<property name="minimize_button">0</property>
|
||||||
<property name="minimum_size">-1,-1</property>
|
<property name="minimum_size">-1,300</property>
|
||||||
<property name="moveable">1</property>
|
<property name="moveable">1</property>
|
||||||
<property name="name">m_panelGrid</property>
|
<property name="name">m_grid</property>
|
||||||
<property name="pane_border">1</property>
|
<property name="pane_border">1</property>
|
||||||
<property name="pane_position"></property>
|
<property name="pane_position"></property>
|
||||||
<property name="pane_size"></property>
|
<property name="pane_size"></property>
|
||||||
|
@ -140,239 +165,15 @@
|
||||||
<property name="pin_button">1</property>
|
<property name="pin_button">1</property>
|
||||||
<property name="pos"></property>
|
<property name="pos"></property>
|
||||||
<property name="resize">Resizable</property>
|
<property name="resize">Resizable</property>
|
||||||
|
<property name="row_label_horiz_alignment">wxALIGN_CENTRE</property>
|
||||||
|
<property name="row_label_size">0</property>
|
||||||
|
<property name="row_label_values"></property>
|
||||||
|
<property name="row_label_vert_alignment">wxALIGN_CENTRE</property>
|
||||||
|
<property name="row_sizes"></property>
|
||||||
|
<property name="rows">5</property>
|
||||||
<property name="show">1</property>
|
<property name="show">1</property>
|
||||||
<property name="size"></property>
|
<property name="size"></property>
|
||||||
<property name="subclass"></property>
|
<property name="subclass">WX_GRID; widgets/wx_grid.h; forward_declare</property>
|
||||||
<property name="toolbar_pane">0</property>
|
|
||||||
<property name="tooltip"></property>
|
|
||||||
<property name="window_extra_style"></property>
|
|
||||||
<property name="window_name"></property>
|
|
||||||
<property name="window_style">wxTAB_TRAVERSAL</property>
|
|
||||||
<event name="OnChar"></event>
|
|
||||||
<event name="OnEnterWindow"></event>
|
|
||||||
<event name="OnEraseBackground"></event>
|
|
||||||
<event name="OnKeyDown"></event>
|
|
||||||
<event name="OnKeyUp"></event>
|
|
||||||
<event name="OnKillFocus"></event>
|
|
||||||
<event name="OnLeaveWindow"></event>
|
|
||||||
<event name="OnLeftDClick"></event>
|
|
||||||
<event name="OnLeftDown"></event>
|
|
||||||
<event name="OnLeftUp"></event>
|
|
||||||
<event name="OnMiddleDClick"></event>
|
|
||||||
<event name="OnMiddleDown"></event>
|
|
||||||
<event name="OnMiddleUp"></event>
|
|
||||||
<event name="OnMotion"></event>
|
|
||||||
<event name="OnMouseEvents"></event>
|
|
||||||
<event name="OnMouseWheel"></event>
|
|
||||||
<event name="OnPaint"></event>
|
|
||||||
<event name="OnRightDClick"></event>
|
|
||||||
<event name="OnRightDown"></event>
|
|
||||||
<event name="OnRightUp"></event>
|
|
||||||
<event name="OnSetFocus"></event>
|
|
||||||
<event name="OnSize"></event>
|
|
||||||
<event name="OnUpdateUI"></event>
|
|
||||||
<object class="wxBoxSizer" expanded="1">
|
|
||||||
<property name="minimum_size"></property>
|
|
||||||
<property name="name">bSizerGrid</property>
|
|
||||||
<property name="orient">wxVERTICAL</property>
|
|
||||||
<property name="permission">none</property>
|
|
||||||
<object class="sizeritem" expanded="0">
|
|
||||||
<property name="border">5</property>
|
|
||||||
<property name="flag">wxALL|wxEXPAND</property>
|
|
||||||
<property name="proportion">1</property>
|
|
||||||
<object class="wxGrid" expanded="0">
|
|
||||||
<property name="BottomDockable">1</property>
|
|
||||||
<property name="LeftDockable">1</property>
|
|
||||||
<property name="RightDockable">1</property>
|
|
||||||
<property name="TopDockable">1</property>
|
|
||||||
<property name="aui_layer"></property>
|
|
||||||
<property name="aui_name"></property>
|
|
||||||
<property name="aui_position"></property>
|
|
||||||
<property name="aui_row"></property>
|
|
||||||
<property name="autosize_cols">0</property>
|
|
||||||
<property name="autosize_rows">1</property>
|
|
||||||
<property name="best_size"></property>
|
|
||||||
<property name="bg"></property>
|
|
||||||
<property name="caption"></property>
|
|
||||||
<property name="caption_visible">1</property>
|
|
||||||
<property name="cell_bg"></property>
|
|
||||||
<property name="cell_font"></property>
|
|
||||||
<property name="cell_horiz_alignment">wxALIGN_LEFT</property>
|
|
||||||
<property name="cell_text"></property>
|
|
||||||
<property name="cell_vert_alignment">wxALIGN_TOP</property>
|
|
||||||
<property name="center_pane">0</property>
|
|
||||||
<property name="close_button">1</property>
|
|
||||||
<property name="col_label_horiz_alignment">wxALIGN_CENTRE</property>
|
|
||||||
<property name="col_label_size">30</property>
|
|
||||||
<property name="col_label_values">"Symbols" "Current Library Reference" "New Library Reference"</property>
|
|
||||||
<property name="col_label_vert_alignment">wxALIGN_CENTRE</property>
|
|
||||||
<property name="cols">3</property>
|
|
||||||
<property name="column_sizes">300,200,200</property>
|
|
||||||
<property name="context_help"></property>
|
|
||||||
<property name="context_menu">1</property>
|
|
||||||
<property name="default_pane">0</property>
|
|
||||||
<property name="dock">Dock</property>
|
|
||||||
<property name="dock_fixed">0</property>
|
|
||||||
<property name="docking">Left</property>
|
|
||||||
<property name="drag_col_move">0</property>
|
|
||||||
<property name="drag_col_size">1</property>
|
|
||||||
<property name="drag_grid_size">0</property>
|
|
||||||
<property name="drag_row_size">1</property>
|
|
||||||
<property name="editing">1</property>
|
|
||||||
<property name="enabled">1</property>
|
|
||||||
<property name="fg"></property>
|
|
||||||
<property name="floatable">1</property>
|
|
||||||
<property name="font"></property>
|
|
||||||
<property name="grid_line_color"></property>
|
|
||||||
<property name="grid_lines">1</property>
|
|
||||||
<property name="gripper">0</property>
|
|
||||||
<property name="hidden">0</property>
|
|
||||||
<property name="id">wxID_ANY</property>
|
|
||||||
<property name="label_bg"></property>
|
|
||||||
<property name="label_font"></property>
|
|
||||||
<property name="label_text"></property>
|
|
||||||
<property name="margin_height">0</property>
|
|
||||||
<property name="margin_width">0</property>
|
|
||||||
<property name="max_size"></property>
|
|
||||||
<property name="maximize_button">0</property>
|
|
||||||
<property name="maximum_size"></property>
|
|
||||||
<property name="min_size"></property>
|
|
||||||
<property name="minimize_button">0</property>
|
|
||||||
<property name="minimum_size">700,-1</property>
|
|
||||||
<property name="moveable">1</property>
|
|
||||||
<property name="name">m_grid</property>
|
|
||||||
<property name="pane_border">1</property>
|
|
||||||
<property name="pane_position"></property>
|
|
||||||
<property name="pane_size"></property>
|
|
||||||
<property name="permission">protected</property>
|
|
||||||
<property name="pin_button">1</property>
|
|
||||||
<property name="pos"></property>
|
|
||||||
<property name="resize">Resizable</property>
|
|
||||||
<property name="row_label_horiz_alignment">wxALIGN_CENTRE</property>
|
|
||||||
<property name="row_label_size">30</property>
|
|
||||||
<property name="row_label_values"></property>
|
|
||||||
<property name="row_label_vert_alignment">wxALIGN_CENTRE</property>
|
|
||||||
<property name="row_sizes"></property>
|
|
||||||
<property name="rows">5</property>
|
|
||||||
<property name="show">1</property>
|
|
||||||
<property name="size"></property>
|
|
||||||
<property name="subclass"></property>
|
|
||||||
<property name="toolbar_pane">0</property>
|
|
||||||
<property name="tooltip"></property>
|
|
||||||
<property name="window_extra_style"></property>
|
|
||||||
<property name="window_name"></property>
|
|
||||||
<property name="window_style"></property>
|
|
||||||
<event name="OnChar"></event>
|
|
||||||
<event name="OnEnterWindow"></event>
|
|
||||||
<event name="OnEraseBackground"></event>
|
|
||||||
<event name="OnGridCellChange"></event>
|
|
||||||
<event name="OnGridCellLeftClick"></event>
|
|
||||||
<event name="OnGridCellLeftDClick">onCellBrowseLib</event>
|
|
||||||
<event name="OnGridCellRightClick">onCellBrowseLib</event>
|
|
||||||
<event name="OnGridCellRightDClick"></event>
|
|
||||||
<event name="OnGridCmdCellChange"></event>
|
|
||||||
<event name="OnGridCmdCellLeftClick"></event>
|
|
||||||
<event name="OnGridCmdCellLeftDClick"></event>
|
|
||||||
<event name="OnGridCmdCellRightClick"></event>
|
|
||||||
<event name="OnGridCmdCellRightDClick"></event>
|
|
||||||
<event name="OnGridCmdColSize"></event>
|
|
||||||
<event name="OnGridCmdEditorCreated"></event>
|
|
||||||
<event name="OnGridCmdEditorHidden"></event>
|
|
||||||
<event name="OnGridCmdEditorShown"></event>
|
|
||||||
<event name="OnGridCmdLabelLeftClick"></event>
|
|
||||||
<event name="OnGridCmdLabelLeftDClick"></event>
|
|
||||||
<event name="OnGridCmdLabelRightClick"></event>
|
|
||||||
<event name="OnGridCmdLabelRightDClick"></event>
|
|
||||||
<event name="OnGridCmdRangeSelect"></event>
|
|
||||||
<event name="OnGridCmdRowSize"></event>
|
|
||||||
<event name="OnGridCmdSelectCell"></event>
|
|
||||||
<event name="OnGridColSize"></event>
|
|
||||||
<event name="OnGridEditorCreated"></event>
|
|
||||||
<event name="OnGridEditorHidden"></event>
|
|
||||||
<event name="OnGridEditorShown"></event>
|
|
||||||
<event name="OnGridLabelLeftClick"></event>
|
|
||||||
<event name="OnGridLabelLeftDClick">onCellBrowseLib</event>
|
|
||||||
<event name="OnGridLabelRightClick">onCellBrowseLib</event>
|
|
||||||
<event name="OnGridLabelRightDClick"></event>
|
|
||||||
<event name="OnGridRangeSelect"></event>
|
|
||||||
<event name="OnGridRowSize"></event>
|
|
||||||
<event name="OnGridSelectCell"></event>
|
|
||||||
<event name="OnKeyDown"></event>
|
|
||||||
<event name="OnKeyUp"></event>
|
|
||||||
<event name="OnKillFocus"></event>
|
|
||||||
<event name="OnLeaveWindow"></event>
|
|
||||||
<event name="OnLeftDClick"></event>
|
|
||||||
<event name="OnLeftDown"></event>
|
|
||||||
<event name="OnLeftUp"></event>
|
|
||||||
<event name="OnMiddleDClick"></event>
|
|
||||||
<event name="OnMiddleDown"></event>
|
|
||||||
<event name="OnMiddleUp"></event>
|
|
||||||
<event name="OnMotion"></event>
|
|
||||||
<event name="OnMouseEvents"></event>
|
|
||||||
<event name="OnMouseWheel"></event>
|
|
||||||
<event name="OnPaint"></event>
|
|
||||||
<event name="OnRightDClick"></event>
|
|
||||||
<event name="OnRightDown"></event>
|
|
||||||
<event name="OnRightUp"></event>
|
|
||||||
<event name="OnSetFocus"></event>
|
|
||||||
<event name="OnSize"></event>
|
|
||||||
<event name="OnUpdateUI"></event>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="sizeritem" expanded="1">
|
|
||||||
<property name="border">5</property>
|
|
||||||
<property name="flag">wxEXPAND | wxALL</property>
|
|
||||||
<property name="proportion">0</property>
|
|
||||||
<object class="wxStaticLine" expanded="1">
|
|
||||||
<property name="BottomDockable">1</property>
|
|
||||||
<property name="LeftDockable">1</property>
|
|
||||||
<property name="RightDockable">1</property>
|
|
||||||
<property name="TopDockable">1</property>
|
|
||||||
<property name="aui_layer"></property>
|
|
||||||
<property name="aui_name"></property>
|
|
||||||
<property name="aui_position"></property>
|
|
||||||
<property name="aui_row"></property>
|
|
||||||
<property name="best_size"></property>
|
|
||||||
<property name="bg"></property>
|
|
||||||
<property name="caption"></property>
|
|
||||||
<property name="caption_visible">1</property>
|
|
||||||
<property name="center_pane">0</property>
|
|
||||||
<property name="close_button">1</property>
|
|
||||||
<property name="context_help"></property>
|
|
||||||
<property name="context_menu">1</property>
|
|
||||||
<property name="default_pane">0</property>
|
|
||||||
<property name="dock">Dock</property>
|
|
||||||
<property name="dock_fixed">0</property>
|
|
||||||
<property name="docking">Left</property>
|
|
||||||
<property name="enabled">1</property>
|
|
||||||
<property name="fg"></property>
|
|
||||||
<property name="floatable">1</property>
|
|
||||||
<property name="font"></property>
|
|
||||||
<property name="gripper">0</property>
|
|
||||||
<property name="hidden">0</property>
|
|
||||||
<property name="id">wxID_ANY</property>
|
|
||||||
<property name="max_size"></property>
|
|
||||||
<property name="maximize_button">0</property>
|
|
||||||
<property name="maximum_size"></property>
|
|
||||||
<property name="min_size"></property>
|
|
||||||
<property name="minimize_button">0</property>
|
|
||||||
<property name="minimum_size"></property>
|
|
||||||
<property name="moveable">1</property>
|
|
||||||
<property name="name">m_staticline</property>
|
|
||||||
<property name="pane_border">1</property>
|
|
||||||
<property name="pane_position"></property>
|
|
||||||
<property name="pane_size"></property>
|
|
||||||
<property name="permission">protected</property>
|
|
||||||
<property name="pin_button">1</property>
|
|
||||||
<property name="pos"></property>
|
|
||||||
<property name="resize">Resizable</property>
|
|
||||||
<property name="show">1</property>
|
|
||||||
<property name="size"></property>
|
|
||||||
<property name="style">wxLI_HORIZONTAL</property>
|
|
||||||
<property name="subclass"></property>
|
|
||||||
<property name="toolbar_pane">0</property>
|
<property name="toolbar_pane">0</property>
|
||||||
<property name="tooltip"></property>
|
<property name="tooltip"></property>
|
||||||
<property name="window_extra_style"></property>
|
<property name="window_extra_style"></property>
|
||||||
|
@ -381,6 +182,38 @@
|
||||||
<event name="OnChar"></event>
|
<event name="OnChar"></event>
|
||||||
<event name="OnEnterWindow"></event>
|
<event name="OnEnterWindow"></event>
|
||||||
<event name="OnEraseBackground"></event>
|
<event name="OnEraseBackground"></event>
|
||||||
|
<event name="OnGridCellChange"></event>
|
||||||
|
<event name="OnGridCellLeftClick"></event>
|
||||||
|
<event name="OnGridCellLeftDClick">onCellBrowseLib</event>
|
||||||
|
<event name="OnGridCellRightClick">onCellBrowseLib</event>
|
||||||
|
<event name="OnGridCellRightDClick"></event>
|
||||||
|
<event name="OnGridCmdCellChange"></event>
|
||||||
|
<event name="OnGridCmdCellLeftClick"></event>
|
||||||
|
<event name="OnGridCmdCellLeftDClick"></event>
|
||||||
|
<event name="OnGridCmdCellRightClick"></event>
|
||||||
|
<event name="OnGridCmdCellRightDClick"></event>
|
||||||
|
<event name="OnGridCmdColSize"></event>
|
||||||
|
<event name="OnGridCmdEditorCreated"></event>
|
||||||
|
<event name="OnGridCmdEditorHidden"></event>
|
||||||
|
<event name="OnGridCmdEditorShown"></event>
|
||||||
|
<event name="OnGridCmdLabelLeftClick"></event>
|
||||||
|
<event name="OnGridCmdLabelLeftDClick"></event>
|
||||||
|
<event name="OnGridCmdLabelRightClick"></event>
|
||||||
|
<event name="OnGridCmdLabelRightDClick"></event>
|
||||||
|
<event name="OnGridCmdRangeSelect"></event>
|
||||||
|
<event name="OnGridCmdRowSize"></event>
|
||||||
|
<event name="OnGridCmdSelectCell"></event>
|
||||||
|
<event name="OnGridColSize"></event>
|
||||||
|
<event name="OnGridEditorCreated"></event>
|
||||||
|
<event name="OnGridEditorHidden"></event>
|
||||||
|
<event name="OnGridEditorShown"></event>
|
||||||
|
<event name="OnGridLabelLeftClick"></event>
|
||||||
|
<event name="OnGridLabelLeftDClick"></event>
|
||||||
|
<event name="OnGridLabelRightClick"></event>
|
||||||
|
<event name="OnGridLabelRightDClick"></event>
|
||||||
|
<event name="OnGridRangeSelect"></event>
|
||||||
|
<event name="OnGridRowSize"></event>
|
||||||
|
<event name="OnGridSelectCell"></event>
|
||||||
<event name="OnKeyDown"></event>
|
<event name="OnKeyDown"></event>
|
||||||
<event name="OnKeyUp"></event>
|
<event name="OnKeyUp"></event>
|
||||||
<event name="OnKillFocus"></event>
|
<event name="OnKillFocus"></event>
|
||||||
|
@ -399,23 +232,23 @@
|
||||||
<event name="OnRightDown"></event>
|
<event name="OnRightDown"></event>
|
||||||
<event name="OnRightUp"></event>
|
<event name="OnRightUp"></event>
|
||||||
<event name="OnSetFocus"></event>
|
<event name="OnSetFocus"></event>
|
||||||
<event name="OnSize"></event>
|
<event name="OnSize">OnSizeGrid</event>
|
||||||
<event name="OnUpdateUI"></event>
|
<event name="OnUpdateUI"></event>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="sizeritem" expanded="1">
|
<object class="sizeritem" expanded="1">
|
||||||
<property name="border">5</property>
|
<property name="border">10</property>
|
||||||
<property name="flag">wxALIGN_CENTER_VERTICAL|wxALIGN_CENTER_HORIZONTAL</property>
|
<property name="flag">wxALIGN_CENTER_VERTICAL|wxALIGN_CENTER_HORIZONTAL|wxEXPAND|wxALL</property>
|
||||||
<property name="proportion">0</property>
|
<property name="proportion">0</property>
|
||||||
<object class="wxBoxSizer" expanded="1">
|
<object class="wxBoxSizer" expanded="1">
|
||||||
<property name="minimum_size"></property>
|
<property name="minimum_size"></property>
|
||||||
<property name="name">bSizerMsgWarning</property>
|
<property name="name">bSizerMsgWarning</property>
|
||||||
<property name="orient">wxVERTICAL</property>
|
<property name="orient">wxHORIZONTAL</property>
|
||||||
<property name="permission">none</property>
|
<property name="permission">none</property>
|
||||||
<object class="sizeritem" expanded="0">
|
<object class="sizeritem" expanded="0">
|
||||||
<property name="border">5</property>
|
<property name="border">5</property>
|
||||||
<property name="flag">wxALL|wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL</property>
|
<property name="flag">wxALIGN_CENTER_HORIZONTAL|wxALIGN_CENTER_VERTICAL|wxTOP|wxBOTTOM|wxRIGHT</property>
|
||||||
<property name="proportion">0</property>
|
<property name="proportion">1</property>
|
||||||
<object class="wxStaticText" expanded="0">
|
<object class="wxStaticText" expanded="0">
|
||||||
<property name="BottomDockable">1</property>
|
<property name="BottomDockable">1</property>
|
||||||
<property name="LeftDockable">1</property>
|
<property name="LeftDockable">1</property>
|
||||||
|
@ -444,7 +277,7 @@
|
||||||
<property name="gripper">0</property>
|
<property name="gripper">0</property>
|
||||||
<property name="hidden">0</property>
|
<property name="hidden">0</property>
|
||||||
<property name="id">wxID_ANY</property>
|
<property name="id">wxID_ANY</property>
|
||||||
<property name="label">Warning: Changes made from this dialog cannot be undone, after closing it.</property>
|
<property name="label">Warning: changes made from this dialog cannot be undone after closing it.</property>
|
||||||
<property name="max_size"></property>
|
<property name="max_size"></property>
|
||||||
<property name="maximize_button">0</property>
|
<property name="maximize_button">0</property>
|
||||||
<property name="maximum_size"></property>
|
<property name="maximum_size"></property>
|
||||||
|
@ -495,46 +328,9 @@
|
||||||
<event name="OnUpdateUI"></event>
|
<event name="OnUpdateUI"></event>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="sizeritem" expanded="1">
|
|
||||||
<property name="border">5</property>
|
|
||||||
<property name="flag">wxALIGN_RIGHT</property>
|
|
||||||
<property name="proportion">0</property>
|
|
||||||
<object class="wxBoxSizer" expanded="1">
|
|
||||||
<property name="minimum_size"></property>
|
|
||||||
<property name="name">bSizerButtons</property>
|
|
||||||
<property name="orient">wxHORIZONTAL</property>
|
|
||||||
<property name="permission">none</property>
|
|
||||||
<object class="sizeritem" expanded="1">
|
<object class="sizeritem" expanded="1">
|
||||||
<property name="border">5</property>
|
<property name="border">5</property>
|
||||||
<property name="flag">wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxALL</property>
|
<property name="flag">wxALIGN_CENTER_VERTICAL|wxALL</property>
|
||||||
<property name="proportion">0</property>
|
|
||||||
<object class="wxStdDialogButtonSizer" expanded="1">
|
|
||||||
<property name="Apply">1</property>
|
|
||||||
<property name="Cancel">1</property>
|
|
||||||
<property name="ContextHelp">0</property>
|
|
||||||
<property name="Help">0</property>
|
|
||||||
<property name="No">0</property>
|
|
||||||
<property name="OK">1</property>
|
|
||||||
<property name="Save">0</property>
|
|
||||||
<property name="Yes">0</property>
|
|
||||||
<property name="minimum_size"></property>
|
|
||||||
<property name="name">m_sdbSizer</property>
|
|
||||||
<property name="permission">protected</property>
|
|
||||||
<event name="OnApplyButtonClick">onApplyButton</event>
|
|
||||||
<event name="OnCancelButtonClick">onCancel</event>
|
|
||||||
<event name="OnContextHelpButtonClick"></event>
|
|
||||||
<event name="OnHelpButtonClick"></event>
|
|
||||||
<event name="OnNoButtonClick"></event>
|
|
||||||
<event name="OnOKButtonClick"></event>
|
|
||||||
<event name="OnSaveButtonClick"></event>
|
|
||||||
<event name="OnYesButtonClick"></event>
|
|
||||||
</object>
|
|
||||||
</object>
|
|
||||||
<object class="sizeritem" expanded="1">
|
|
||||||
<property name="border">5</property>
|
|
||||||
<property name="flag">wxTOP|wxBOTTOM|wxRIGHT|wxALIGN_CENTER_VERTICAL</property>
|
|
||||||
<property name="proportion">0</property>
|
<property name="proportion">0</property>
|
||||||
<object class="wxButton" expanded="1">
|
<object class="wxButton" expanded="1">
|
||||||
<property name="BottomDockable">1</property>
|
<property name="BottomDockable">1</property>
|
||||||
|
@ -620,94 +416,98 @@
|
||||||
<event name="OnUpdateUI">updateUIChangesButton</event>
|
<event name="OnUpdateUI">updateUIChangesButton</event>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
<object class="sizeritem" expanded="1">
|
</object>
|
||||||
<property name="border">5</property>
|
</object>
|
||||||
<property name="flag">wxALL|wxALIGN_CENTER_VERTICAL</property>
|
<object class="sizeritem" expanded="1">
|
||||||
<property name="proportion">0</property>
|
<property name="border">5</property>
|
||||||
<object class="wxButton" expanded="1">
|
<property name="flag">wxEXPAND|wxRIGHT|wxLEFT</property>
|
||||||
<property name="BottomDockable">1</property>
|
<property name="proportion">0</property>
|
||||||
<property name="LeftDockable">1</property>
|
<object class="wxStaticLine" expanded="1">
|
||||||
<property name="RightDockable">1</property>
|
<property name="BottomDockable">1</property>
|
||||||
<property name="TopDockable">1</property>
|
<property name="LeftDockable">1</property>
|
||||||
<property name="aui_layer"></property>
|
<property name="RightDockable">1</property>
|
||||||
<property name="aui_name"></property>
|
<property name="TopDockable">1</property>
|
||||||
<property name="aui_position"></property>
|
<property name="aui_layer"></property>
|
||||||
<property name="aui_row"></property>
|
<property name="aui_name"></property>
|
||||||
<property name="best_size"></property>
|
<property name="aui_position"></property>
|
||||||
<property name="bg"></property>
|
<property name="aui_row"></property>
|
||||||
<property name="caption"></property>
|
<property name="best_size"></property>
|
||||||
<property name="caption_visible">1</property>
|
<property name="bg"></property>
|
||||||
<property name="center_pane">0</property>
|
<property name="caption"></property>
|
||||||
<property name="close_button">1</property>
|
<property name="caption_visible">1</property>
|
||||||
<property name="context_help"></property>
|
<property name="center_pane">0</property>
|
||||||
<property name="context_menu">1</property>
|
<property name="close_button">1</property>
|
||||||
<property name="default">0</property>
|
<property name="context_help"></property>
|
||||||
<property name="default_pane">0</property>
|
<property name="context_menu">1</property>
|
||||||
<property name="dock">Dock</property>
|
<property name="default_pane">0</property>
|
||||||
<property name="dock_fixed">0</property>
|
<property name="dock">Dock</property>
|
||||||
<property name="docking">Left</property>
|
<property name="dock_fixed">0</property>
|
||||||
<property name="enabled">1</property>
|
<property name="docking">Left</property>
|
||||||
<property name="fg"></property>
|
<property name="enabled">1</property>
|
||||||
<property name="floatable">1</property>
|
<property name="fg"></property>
|
||||||
<property name="font"></property>
|
<property name="floatable">1</property>
|
||||||
<property name="gripper">0</property>
|
<property name="font"></property>
|
||||||
<property name="hidden">0</property>
|
<property name="gripper">0</property>
|
||||||
<property name="id">wxID_ANY</property>
|
<property name="hidden">0</property>
|
||||||
<property name="label">Browse Libraries</property>
|
<property name="id">wxID_ANY</property>
|
||||||
<property name="max_size"></property>
|
<property name="max_size"></property>
|
||||||
<property name="maximize_button">0</property>
|
<property name="maximize_button">0</property>
|
||||||
<property name="maximum_size"></property>
|
<property name="maximum_size"></property>
|
||||||
<property name="min_size"></property>
|
<property name="min_size"></property>
|
||||||
<property name="minimize_button">0</property>
|
<property name="minimize_button">0</property>
|
||||||
<property name="minimum_size"></property>
|
<property name="minimum_size"></property>
|
||||||
<property name="moveable">1</property>
|
<property name="moveable">1</property>
|
||||||
<property name="name">m_buttonBrowseLibs</property>
|
<property name="name">m_staticline2</property>
|
||||||
<property name="pane_border">1</property>
|
<property name="pane_border">1</property>
|
||||||
<property name="pane_position"></property>
|
<property name="pane_position"></property>
|
||||||
<property name="pane_size"></property>
|
<property name="pane_size"></property>
|
||||||
<property name="permission">protected</property>
|
<property name="permission">protected</property>
|
||||||
<property name="pin_button">1</property>
|
<property name="pin_button">1</property>
|
||||||
<property name="pos"></property>
|
<property name="pos"></property>
|
||||||
<property name="resize">Resizable</property>
|
<property name="resize">Resizable</property>
|
||||||
<property name="show">1</property>
|
<property name="show">1</property>
|
||||||
<property name="size"></property>
|
<property name="size"></property>
|
||||||
<property name="style"></property>
|
<property name="style">wxLI_HORIZONTAL</property>
|
||||||
<property name="subclass"></property>
|
<property name="subclass">; forward_declare</property>
|
||||||
<property name="toolbar_pane">0</property>
|
<property name="toolbar_pane">0</property>
|
||||||
<property name="tooltip"></property>
|
<property name="tooltip"></property>
|
||||||
<property name="validator_data_type"></property>
|
<property name="window_extra_style"></property>
|
||||||
<property name="validator_style">wxFILTER_NONE</property>
|
<property name="window_name"></property>
|
||||||
<property name="validator_type">wxDefaultValidator</property>
|
<property name="window_style"></property>
|
||||||
<property name="validator_variable"></property>
|
<event name="OnChar"></event>
|
||||||
<property name="window_extra_style"></property>
|
<event name="OnEnterWindow"></event>
|
||||||
<property name="window_name"></property>
|
<event name="OnEraseBackground"></event>
|
||||||
<property name="window_style"></property>
|
<event name="OnKeyDown"></event>
|
||||||
<event name="OnButtonClick">onButtonBrowseLibraries</event>
|
<event name="OnKeyUp"></event>
|
||||||
<event name="OnChar"></event>
|
<event name="OnKillFocus"></event>
|
||||||
<event name="OnEnterWindow"></event>
|
<event name="OnLeaveWindow"></event>
|
||||||
<event name="OnEraseBackground"></event>
|
<event name="OnLeftDClick"></event>
|
||||||
<event name="OnKeyDown"></event>
|
<event name="OnLeftDown"></event>
|
||||||
<event name="OnKeyUp"></event>
|
<event name="OnLeftUp"></event>
|
||||||
<event name="OnKillFocus"></event>
|
<event name="OnMiddleDClick"></event>
|
||||||
<event name="OnLeaveWindow"></event>
|
<event name="OnMiddleDown"></event>
|
||||||
<event name="OnLeftDClick"></event>
|
<event name="OnMiddleUp"></event>
|
||||||
<event name="OnLeftDown"></event>
|
<event name="OnMotion"></event>
|
||||||
<event name="OnLeftUp"></event>
|
<event name="OnMouseEvents"></event>
|
||||||
<event name="OnMiddleDClick"></event>
|
<event name="OnMouseWheel"></event>
|
||||||
<event name="OnMiddleDown"></event>
|
<event name="OnPaint"></event>
|
||||||
<event name="OnMiddleUp"></event>
|
<event name="OnRightDClick"></event>
|
||||||
<event name="OnMotion"></event>
|
<event name="OnRightDown"></event>
|
||||||
<event name="OnMouseEvents"></event>
|
<event name="OnRightUp"></event>
|
||||||
<event name="OnMouseWheel"></event>
|
<event name="OnSetFocus"></event>
|
||||||
<event name="OnPaint"></event>
|
<event name="OnSize"></event>
|
||||||
<event name="OnRightDClick"></event>
|
<event name="OnUpdateUI"></event>
|
||||||
<event name="OnRightDown"></event>
|
</object>
|
||||||
<event name="OnRightUp"></event>
|
</object>
|
||||||
<event name="OnSetFocus"></event>
|
<object class="sizeritem" expanded="1">
|
||||||
<event name="OnSize"></event>
|
<property name="border">5</property>
|
||||||
<event name="OnUpdateUI">updateUIBrowseButton</event>
|
<property name="flag">wxALIGN_RIGHT|wxEXPAND|wxLEFT</property>
|
||||||
</object>
|
<property name="proportion">0</property>
|
||||||
</object>
|
<object class="wxBoxSizer" expanded="1">
|
||||||
|
<property name="minimum_size"></property>
|
||||||
|
<property name="name">bSizerButtons</property>
|
||||||
|
<property name="orient">wxHORIZONTAL</property>
|
||||||
|
<property name="permission">none</property>
|
||||||
<object class="sizeritem" expanded="1">
|
<object class="sizeritem" expanded="1">
|
||||||
<property name="border">5</property>
|
<property name="border">5</property>
|
||||||
<property name="flag">wxALL|wxALIGN_CENTER_VERTICAL</property>
|
<property name="flag">wxALL|wxALIGN_CENTER_VERTICAL</property>
|
||||||
|
@ -796,6 +596,32 @@
|
||||||
<event name="OnUpdateUI"></event>
|
<event name="OnUpdateUI"></event>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="sizeritem" expanded="1">
|
||||||
|
<property name="border">5</property>
|
||||||
|
<property name="flag">wxALIGN_RIGHT|wxALIGN_CENTER_VERTICAL|wxALL</property>
|
||||||
|
<property name="proportion">1</property>
|
||||||
|
<object class="wxStdDialogButtonSizer" expanded="1">
|
||||||
|
<property name="Apply">1</property>
|
||||||
|
<property name="Cancel">1</property>
|
||||||
|
<property name="ContextHelp">0</property>
|
||||||
|
<property name="Help">0</property>
|
||||||
|
<property name="No">0</property>
|
||||||
|
<property name="OK">1</property>
|
||||||
|
<property name="Save">0</property>
|
||||||
|
<property name="Yes">0</property>
|
||||||
|
<property name="minimum_size"></property>
|
||||||
|
<property name="name">m_sdbSizer</property>
|
||||||
|
<property name="permission">protected</property>
|
||||||
|
<event name="OnApplyButtonClick">onApplyButton</event>
|
||||||
|
<event name="OnCancelButtonClick">onCancel</event>
|
||||||
|
<event name="OnContextHelpButtonClick"></event>
|
||||||
|
<event name="OnHelpButtonClick"></event>
|
||||||
|
<event name="OnNoButtonClick"></event>
|
||||||
|
<event name="OnOKButtonClick"></event>
|
||||||
|
<event name="OnSaveButtonClick"></event>
|
||||||
|
<event name="OnYesButtonClick"></event>
|
||||||
|
</object>
|
||||||
|
</object>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
</object>
|
</object>
|
||||||
|
|
|
@ -11,6 +11,8 @@
|
||||||
#include <wx/artprov.h>
|
#include <wx/artprov.h>
|
||||||
#include <wx/xrc/xmlres.h>
|
#include <wx/xrc/xmlres.h>
|
||||||
#include <wx/intl.h>
|
#include <wx/intl.h>
|
||||||
|
class WX_GRID;
|
||||||
|
|
||||||
#include "dialog_shim.h"
|
#include "dialog_shim.h"
|
||||||
#include <wx/colour.h>
|
#include <wx/colour.h>
|
||||||
#include <wx/settings.h>
|
#include <wx/settings.h>
|
||||||
|
@ -18,11 +20,10 @@
|
||||||
#include <wx/font.h>
|
#include <wx/font.h>
|
||||||
#include <wx/grid.h>
|
#include <wx/grid.h>
|
||||||
#include <wx/gdicmn.h>
|
#include <wx/gdicmn.h>
|
||||||
#include <wx/sizer.h>
|
|
||||||
#include <wx/panel.h>
|
|
||||||
#include <wx/statline.h>
|
|
||||||
#include <wx/stattext.h>
|
#include <wx/stattext.h>
|
||||||
#include <wx/button.h>
|
#include <wx/button.h>
|
||||||
|
#include <wx/sizer.h>
|
||||||
|
#include <wx/statline.h>
|
||||||
#include <wx/dialog.h>
|
#include <wx/dialog.h>
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -36,27 +37,24 @@ class DIALOG_EDIT_COMPONENTS_LIBID_BASE : public DIALOG_SHIM
|
||||||
private:
|
private:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
wxPanel* m_panelGrid;
|
WX_GRID* m_grid;
|
||||||
wxGrid* m_grid;
|
|
||||||
wxStaticLine* m_staticline;
|
|
||||||
wxStaticText* m_staticTextWarning;
|
wxStaticText* m_staticTextWarning;
|
||||||
|
wxButton* m_buttonUndo;
|
||||||
|
wxStaticLine* m_staticline2;
|
||||||
|
wxButton* m_buttonOrphanItems;
|
||||||
wxStdDialogButtonSizer* m_sdbSizer;
|
wxStdDialogButtonSizer* m_sdbSizer;
|
||||||
wxButton* m_sdbSizerOK;
|
wxButton* m_sdbSizerOK;
|
||||||
wxButton* m_sdbSizerApply;
|
wxButton* m_sdbSizerApply;
|
||||||
wxButton* m_sdbSizerCancel;
|
wxButton* m_sdbSizerCancel;
|
||||||
wxButton* m_buttonUndo;
|
|
||||||
wxButton* m_buttonBrowseLibs;
|
|
||||||
wxButton* m_buttonOrphanItems;
|
|
||||||
|
|
||||||
// Virtual event handlers, overide them in your derived class
|
// Virtual event handlers, overide them in your derived class
|
||||||
virtual void onCellBrowseLib( wxGridEvent& event ) { event.Skip(); }
|
virtual void onCellBrowseLib( wxGridEvent& event ) { event.Skip(); }
|
||||||
virtual void onApplyButton( wxCommandEvent& event ) { event.Skip(); }
|
virtual void OnSizeGrid( wxSizeEvent& event ) { event.Skip(); }
|
||||||
virtual void onCancel( wxCommandEvent& event ) { event.Skip(); }
|
|
||||||
virtual void onUndoChangesButton( wxCommandEvent& event ) { event.Skip(); }
|
virtual void onUndoChangesButton( wxCommandEvent& event ) { event.Skip(); }
|
||||||
virtual void updateUIChangesButton( wxUpdateUIEvent& event ) { event.Skip(); }
|
virtual void updateUIChangesButton( wxUpdateUIEvent& event ) { event.Skip(); }
|
||||||
virtual void onButtonBrowseLibraries( wxCommandEvent& event ) { event.Skip(); }
|
|
||||||
virtual void updateUIBrowseButton( wxUpdateUIEvent& event ) { event.Skip(); }
|
|
||||||
virtual void onClickOrphansButton( wxCommandEvent& event ) { event.Skip(); }
|
virtual void onClickOrphansButton( wxCommandEvent& event ) { event.Skip(); }
|
||||||
|
virtual void onApplyButton( wxCommandEvent& event ) { event.Skip(); }
|
||||||
|
virtual void onCancel( wxCommandEvent& event ) { event.Skip(); }
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in New Issue