2011-02-21 18:27:47 +00:00
|
|
|
/**
|
|
|
|
* @file class_footprints_listbox.cpp
|
|
|
|
* class to display the list fo available footprints
|
|
|
|
*/
|
2009-08-20 11:44:06 +00:00
|
|
|
|
|
|
|
#include "fctsys.h"
|
|
|
|
#include "wxstruct.h"
|
2011-09-23 13:57:12 +00:00
|
|
|
#include "macros.h"
|
2009-08-20 11:44:06 +00:00
|
|
|
|
|
|
|
#include "cvpcb.h"
|
2011-02-05 16:15:48 +00:00
|
|
|
#include "cvpcb_mainframe.h"
|
2009-08-20 11:44:06 +00:00
|
|
|
#include "cvstruct.h"
|
|
|
|
|
|
|
|
|
|
|
|
/***************************************/
|
|
|
|
/* ListBox handling the footprint list */
|
|
|
|
/***************************************/
|
|
|
|
|
2011-02-05 16:15:48 +00:00
|
|
|
FOOTPRINTS_LISTBOX::FOOTPRINTS_LISTBOX( CVPCB_MAINFRAME* parent,
|
2009-08-20 11:44:06 +00:00
|
|
|
wxWindowID id, const wxPoint& loc,
|
|
|
|
const wxSize& size,
|
|
|
|
int nbitems, wxString choice[] ) :
|
|
|
|
ITEMS_LISTBOX_BASE( parent, id, loc, size )
|
|
|
|
{
|
|
|
|
m_UseFootprintFullList = true;
|
|
|
|
m_ActiveFootprintList = NULL;
|
2010-11-07 20:06:07 +00:00
|
|
|
SetActiveFootprintList( true );
|
2009-08-20 11:44:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FOOTPRINTS_LISTBOX::~FOOTPRINTS_LISTBOX()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return number of items
|
|
|
|
*/
|
|
|
|
int FOOTPRINTS_LISTBOX::GetCount()
|
|
|
|
{
|
|
|
|
return m_ActiveFootprintList->Count();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Change an item text
|
|
|
|
*/
|
|
|
|
void FOOTPRINTS_LISTBOX::SetString( unsigned linecount, const wxString& text )
|
|
|
|
{
|
|
|
|
if( linecount >= m_ActiveFootprintList->Count() )
|
|
|
|
linecount = m_ActiveFootprintList->Count() - 1;
|
|
|
|
if( linecount >= 0 )
|
|
|
|
(*m_ActiveFootprintList)[linecount] = text;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
wxString FOOTPRINTS_LISTBOX::GetSelectedFootprint()
|
|
|
|
{
|
|
|
|
wxString FootprintName;
|
|
|
|
int ii = GetFirstSelected();
|
|
|
|
|
|
|
|
if( ii >= 0 )
|
|
|
|
{
|
|
|
|
wxString msg = (*m_ActiveFootprintList)[ii];
|
2010-11-07 20:06:07 +00:00
|
|
|
msg.Trim( true );
|
|
|
|
msg.Trim( false );
|
2009-08-20 11:44:06 +00:00
|
|
|
FootprintName = msg.AfterFirst( wxChar( ' ' ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
return FootprintName;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FOOTPRINTS_LISTBOX::AppendLine( const wxString& text )
|
|
|
|
{
|
|
|
|
m_ActiveFootprintList->Add( text );
|
|
|
|
SetItemCount( m_ActiveFootprintList->Count() );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Overlaid function: MUST be provided in wxLC_VIRTUAL mode
|
|
|
|
* because real data is not handled by ITEMS_LISTBOX_BASE
|
|
|
|
*/
|
|
|
|
wxString FOOTPRINTS_LISTBOX::OnGetItemText( long item, long column ) const
|
|
|
|
{
|
|
|
|
return m_ActiveFootprintList->Item( item );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Enable or disable an item
|
|
|
|
*/
|
|
|
|
void FOOTPRINTS_LISTBOX::SetSelection( unsigned index, bool State )
|
|
|
|
{
|
|
|
|
if( (int) index >= GetCount() )
|
|
|
|
index = GetCount() - 1;
|
|
|
|
|
|
|
|
if( (index >= 0) && (GetCount() > 0) )
|
|
|
|
{
|
|
|
|
#ifndef __WXMAC__
|
|
|
|
Select( index, State );
|
|
|
|
#endif
|
|
|
|
EnsureVisible( index );
|
|
|
|
#ifdef __WXMAC__
|
|
|
|
Refresh();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FOOTPRINTS_LISTBOX::SetFootprintFullList( FOOTPRINT_LIST& list )
|
|
|
|
{
|
|
|
|
wxString msg;
|
|
|
|
int OldSelection = GetSelection();
|
|
|
|
|
|
|
|
m_FullFootprintList.Clear();
|
|
|
|
|
2011-02-22 17:59:46 +00:00
|
|
|
for( unsigned ii = 0; ii < list.GetCount(); ii++ )
|
|
|
|
{
|
|
|
|
FOOTPRINT_INFO & footprint = list.GetItem(ii);
|
2012-01-04 06:18:38 +00:00
|
|
|
msg.Printf( wxT( "%3d %s" ), (int) m_FullFootprintList.GetCount() + 1,
|
2011-02-22 17:59:46 +00:00
|
|
|
GetChars(footprint.m_Module) );
|
2009-08-20 11:44:06 +00:00
|
|
|
m_FullFootprintList.Add( msg );
|
|
|
|
}
|
|
|
|
|
2010-11-07 20:06:07 +00:00
|
|
|
SetActiveFootprintList( true );
|
2009-08-20 11:44:06 +00:00
|
|
|
|
|
|
|
if( ( GetCount() == 0 )
|
|
|
|
|| ( OldSelection < 0 ) || ( OldSelection >= GetCount() ) )
|
2010-11-07 20:06:07 +00:00
|
|
|
SetSelection( 0, true );
|
2009-08-20 11:44:06 +00:00
|
|
|
Refresh();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void FOOTPRINTS_LISTBOX::SetFootprintFilteredList( COMPONENT* Component,
|
|
|
|
FOOTPRINT_LIST& list )
|
|
|
|
{
|
|
|
|
wxString msg;
|
|
|
|
unsigned jj;
|
|
|
|
int OldSelection = GetSelection();
|
2010-11-07 20:06:07 +00:00
|
|
|
bool HasItem = false;
|
2009-08-20 11:44:06 +00:00
|
|
|
|
|
|
|
m_FilteredFootprintList.Clear();
|
|
|
|
|
2011-02-22 17:59:46 +00:00
|
|
|
for( unsigned ii = 0; ii < list.GetCount(); ii++ )
|
|
|
|
{
|
|
|
|
FOOTPRINT_INFO& footprint = list.GetItem(ii);
|
2011-10-14 16:44:15 +00:00
|
|
|
// Search for matching footprints
|
|
|
|
// The search is case insensitive
|
|
|
|
wxString module = footprint.m_Module.Upper();
|
|
|
|
wxString candidate;
|
2009-08-20 11:44:06 +00:00
|
|
|
for( jj = 0; jj < Component->m_FootprintFilter.GetCount(); jj++ )
|
|
|
|
{
|
2011-10-14 16:44:15 +00:00
|
|
|
candidate = Component->m_FootprintFilter[jj].Upper();
|
|
|
|
if( !module.Matches( candidate ) )
|
2009-08-20 11:44:06 +00:00
|
|
|
continue;
|
|
|
|
msg.Printf( wxT( "%3d %s" ), m_FilteredFootprintList.GetCount() + 1,
|
|
|
|
footprint.m_Module.GetData() );
|
|
|
|
m_FilteredFootprintList.Add( msg );
|
2010-11-07 20:06:07 +00:00
|
|
|
HasItem = true;
|
2009-08-20 11:44:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( HasItem )
|
2010-11-07 20:06:07 +00:00
|
|
|
SetActiveFootprintList( false );
|
2009-08-20 11:44:06 +00:00
|
|
|
else
|
2010-11-07 20:06:07 +00:00
|
|
|
SetActiveFootprintList( true );
|
2009-08-20 11:44:06 +00:00
|
|
|
|
|
|
|
if( ( GetCount() == 0 ) || ( OldSelection >= GetCount() ) )
|
2010-11-07 20:06:07 +00:00
|
|
|
SetSelection( 0, true );
|
2009-08-20 11:44:06 +00:00
|
|
|
|
|
|
|
Refresh();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/** Set the footprint list. We can have 2 footprint list:
|
|
|
|
* The full footprint list
|
|
|
|
* The filtered footprint list (if the current selected component has a
|
|
|
|
* filter for footprints)
|
|
|
|
* @param FullList true = full footprint list, false = filtered footprint list
|
|
|
|
* @param Redraw = true to redraw the window
|
|
|
|
*/
|
|
|
|
void FOOTPRINTS_LISTBOX::SetActiveFootprintList( bool FullList, bool Redraw )
|
|
|
|
{
|
|
|
|
bool old_selection = m_UseFootprintFullList;
|
|
|
|
|
|
|
|
#ifdef __WINDOWS__
|
|
|
|
|
|
|
|
/* Workaround for a curious bug in wxWidgets:
|
|
|
|
* if we switch from a long list of footprints to a short list (a
|
|
|
|
* filtered footprint list), and if the selected item is near the end
|
|
|
|
* of the long list, the new list is not displayed from the top of
|
|
|
|
* the list box
|
|
|
|
*/
|
|
|
|
if( m_ActiveFootprintList )
|
|
|
|
{
|
|
|
|
bool new_selection;
|
|
|
|
if( FullList )
|
2010-11-07 20:06:07 +00:00
|
|
|
new_selection = true;
|
2009-08-20 11:44:06 +00:00
|
|
|
else
|
2010-11-07 20:06:07 +00:00
|
|
|
new_selection = false;
|
2009-08-20 11:44:06 +00:00
|
|
|
if( new_selection != old_selection )
|
2010-11-07 20:06:07 +00:00
|
|
|
SetSelection( 0, true );
|
2009-08-20 11:44:06 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
if( FullList )
|
|
|
|
{
|
2010-11-07 20:06:07 +00:00
|
|
|
m_UseFootprintFullList = true;
|
2009-08-20 11:44:06 +00:00
|
|
|
m_ActiveFootprintList = &m_FullFootprintList;
|
|
|
|
SetItemCount( m_FullFootprintList.GetCount() );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2010-11-07 20:06:07 +00:00
|
|
|
m_UseFootprintFullList = false;
|
2009-08-20 11:44:06 +00:00
|
|
|
m_ActiveFootprintList = &m_FilteredFootprintList;
|
|
|
|
SetItemCount( m_FilteredFootprintList.GetCount() );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( Redraw )
|
|
|
|
{
|
2010-11-07 20:06:07 +00:00
|
|
|
if( !m_UseFootprintFullList || ( m_UseFootprintFullList != old_selection ) )
|
2009-08-20 11:44:06 +00:00
|
|
|
{
|
|
|
|
Refresh();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-11-07 20:06:07 +00:00
|
|
|
GetParent()->DisplayStatus();
|
2009-08-20 11:44:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**************************************/
|
|
|
|
/* Event table for the footprint list */
|
|
|
|
/**************************************/
|
|
|
|
|
|
|
|
BEGIN_EVENT_TABLE( FOOTPRINTS_LISTBOX, ITEMS_LISTBOX_BASE )
|
|
|
|
EVT_SIZE( ITEMS_LISTBOX_BASE::OnSize )
|
|
|
|
EVT_CHAR( FOOTPRINTS_LISTBOX::OnChar )
|
|
|
|
END_EVENT_TABLE()
|
|
|
|
|
|
|
|
|
|
|
|
/********************************************************/
|
|
|
|
void FOOTPRINTS_LISTBOX::OnLeftClick( wxListEvent& event )
|
|
|
|
/********************************************************/
|
|
|
|
{
|
2011-02-21 18:27:47 +00:00
|
|
|
FOOTPRINT_INFO* Module;
|
2009-08-20 11:44:06 +00:00
|
|
|
wxString FootprintName = GetSelectedFootprint();
|
|
|
|
|
2011-02-22 17:59:46 +00:00
|
|
|
Module = GetParent()->m_footprints.GetModuleInfo( FootprintName );
|
2010-11-07 20:06:07 +00:00
|
|
|
wxASSERT(Module);
|
2011-08-04 11:23:19 +00:00
|
|
|
if( GetParent()->m_DisplayFootprintFrame )
|
2009-08-20 11:44:06 +00:00
|
|
|
{
|
|
|
|
GetParent()->CreateScreenCmp(); /* refresh general */
|
|
|
|
}
|
|
|
|
|
|
|
|
if( Module )
|
|
|
|
{
|
|
|
|
wxString msg;
|
|
|
|
msg = Module->m_Doc;
|
|
|
|
GetParent()->SetStatusText( msg, 0 );
|
|
|
|
|
|
|
|
msg = wxT( "KeyW: " );
|
|
|
|
msg += Module->m_KeyWord;
|
|
|
|
GetParent()->SetStatusText( msg, 1 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************/
|
|
|
|
void FOOTPRINTS_LISTBOX::OnLeftDClick( wxListEvent& event )
|
|
|
|
/******************************************************/
|
|
|
|
{
|
|
|
|
wxString FootprintName = GetSelectedFootprint();
|
|
|
|
|
|
|
|
GetParent()->SetNewPkg( FootprintName );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-11-12 16:36:43 +00:00
|
|
|
/**
|
|
|
|
* Function OnChar
|
2009-08-20 11:44:06 +00:00
|
|
|
* called on a key pressed
|
|
|
|
* Call default handler for some special keys,
|
|
|
|
* and for "ascii" keys, select the first footprint
|
|
|
|
* that the name starts by the letter.
|
|
|
|
* This is the defaut behaviour of a listbox, but because we use
|
|
|
|
* virtual lists, the listbox does not know anything to what is displayed,
|
|
|
|
* we must handle this behaviour here.
|
|
|
|
* Furthermore the footprint name is not at the beginning of
|
|
|
|
* displayed lines (the first word is the line number)
|
|
|
|
*/
|
|
|
|
void FOOTPRINTS_LISTBOX::OnChar( wxKeyEvent& event )
|
|
|
|
{
|
|
|
|
int key = event.GetKeyCode();
|
|
|
|
switch( key )
|
|
|
|
{
|
|
|
|
case WXK_LEFT:
|
|
|
|
case WXK_NUMPAD_LEFT:
|
|
|
|
GetParent()->m_ListCmp->SetFocus();
|
|
|
|
return;
|
|
|
|
|
|
|
|
case WXK_HOME:
|
|
|
|
case WXK_END:
|
|
|
|
case WXK_UP:
|
|
|
|
case WXK_DOWN:
|
|
|
|
case WXK_PAGEUP:
|
|
|
|
case WXK_PAGEDOWN:
|
|
|
|
case WXK_RIGHT:
|
|
|
|
case WXK_NUMPAD_RIGHT:
|
|
|
|
event.Skip();
|
|
|
|
return;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
// Search for an item name starting by the key code:
|
|
|
|
key = toupper(key);
|
|
|
|
for( unsigned ii = 0; ii < m_ActiveFootprintList->GetCount(); ii++ )
|
|
|
|
{
|
|
|
|
wxString text = m_ActiveFootprintList->Item(ii);
|
|
|
|
/* search for the start char of the footprint name.
|
|
|
|
* we must skip the line number
|
|
|
|
*/
|
|
|
|
text.Trim(false); // Remove leading spaces in line
|
|
|
|
unsigned jj = 0;
|
|
|
|
for( ; jj < text.Len(); jj++ )
|
|
|
|
{ // skip line number
|
|
|
|
if( text[jj] == ' ' )
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
for( ; jj < text.Len(); jj++ )
|
|
|
|
{ // skip blanks
|
|
|
|
if( text[jj] != ' ' )
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
int start_char = toupper(text[jj]);
|
|
|
|
if ( key == start_char )
|
|
|
|
{
|
|
|
|
Focus( ii );
|
|
|
|
SetSelection( ii, true ); // Ensure visible
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|