-#if TARGET_CARBON
- GetListCellSize(m_macList, &pt);
-#else
- pt = (**m_macList).cellSize ;
-#endif
- pt.h = m_width - 15 ;
- LCellSize( pt , m_macList ) ;
-}
-
-void wxListBox::MacHandleControlClick( ControlHandle control , SInt16 controlpart )
-{
- Boolean wasDoubleClick = false ;
- long result ;
-
- ::GetControlData( m_macControl , kControlNoPart , kControlListBoxDoubleClickTag , sizeof( wasDoubleClick ) , (char*) &wasDoubleClick , &result ) ;
- if ( !wasDoubleClick )
- {
- MacDoClick() ;
- }
- else
- {
- MacDoDoubleClick() ;
- }
-}
-
-void wxListBox::MacSetRedraw( bool doDraw )
-{
- LSetDrawingMode( doDraw , m_macList ) ;
-
-}
-
-void wxListBox::MacDoClick()
-{
- wxArrayInt aSelections;
- int n, count = GetSelections(aSelections);
-
- if ( count == m_selectionPreImage.GetCount() )
- {
- bool hasChanged = false ;
- for ( int i = 0 ; i < count ; ++i )
- {
- if ( aSelections[i] != m_selectionPreImage[i] )
- {
- hasChanged = true ;
- break ;
- }
- }
- if ( !hasChanged )
- return ;
- }
-
- wxCommandEvent event(wxEVT_COMMAND_LISTBOX_SELECTED, m_windowId);
- event.SetEventObject( this );
-
- if ( count > 0 )
- {
- n = aSelections[0];
- if ( HasClientObjectData() )
- event.SetClientObject( GetClientObject(n) );
- else if ( HasClientUntypedData() )
- event.SetClientData( GetClientData(n) );
- event.SetString( GetString(n) );
- }
- else
- {
- n = -1;
- }
-
- event.m_commandInt = n;
-
- GetEventHandler()->ProcessEvent(event);
-}
-
-void wxListBox::MacDoDoubleClick()
-{
- wxCommandEvent event(wxEVT_COMMAND_LISTBOX_DOUBLECLICKED, m_windowId);
- event.SetEventObject( this );
- GetEventHandler()->ProcessEvent(event) ;
+ // TODO: binary search would be faster
+ int count = GetCount();
+ DataBrowserTableViewColumnID colId = 0;
+
+ //Get column property id (req. for call to itempartbounds)
+ GetDataBrowserTableViewColumnProperty(m_peer->GetControlRef(), 0, &colId);
+
+ for(int i = 1; i <= count; ++i)
+ {
+ Rect bounds;
+ GetDataBrowserItemPartBounds(m_peer->GetControlRef(), i, colId,
+ kDataBrowserPropertyEnclosingPart,
+ &bounds);
+
+ //translate to client coords
+ //
+ // TODO: it would probably be more efficient to translate point to
+ // screen coordinates once outside of the loop
+ MacRootWindowToWindow(&bounds.left, &bounds.top);
+ MacRootWindowToWindow(&bounds.right, &bounds.bottom);
+
+ //if point is within the bounds, return this item
+ if( (point.x >= bounds.left && point.x <= bounds.right) &&
+ (point.y >= bounds.top && point.y <= bounds.bottom) )
+ {
+ return i - 1; //found
+ }
+ }
+
+ return wxNOT_FOUND;
+}
+
+#if !TARGET_API_MAC_OSX
+
+void wxListBox::OnChar(wxKeyEvent& event)
+{
+ // TODO: trigger proper events here
+ event.Skip() ;
+ return ;
+
+ if ( event.GetKeyCode() == WXK_RETURN || event.GetKeyCode() == WXK_NUMPAD_ENTER)
+ {
+ wxWindow* parent = GetParent() ;
+
+ while ( parent && !parent->IsTopLevel() && parent->GetDefaultItem() == NULL )
+ parent = parent->GetParent() ;
+
+ if ( parent && parent->GetDefaultItem() )
+ {
+ wxButton *def = wxDynamicCast(parent->GetDefaultItem(), wxButton);
+ if ( def && def->IsEnabled() )
+ {
+ wxCommandEvent event( wxEVT_COMMAND_BUTTON_CLICKED, def->GetId() );
+ event.SetEventObject( def );
+ def->Command( event );
+
+ return ;
+ }
+ }
+
+ event.Skip() ;
+ }
+
+ /* generate wxID_CANCEL if command-. or <esc> has been pressed (typically in dialogs) */
+ else if (event.GetKeyCode() == WXK_ESCAPE || (event.GetKeyCode() == '.' && event.MetaDown() ) )
+ {
+ // FIXME: look in ancestors, not just parent.
+ wxWindow* win = GetParent()->FindWindow( wxID_CANCEL ) ;
+ if (win)
+ {
+ wxCommandEvent new_event(wxEVT_COMMAND_BUTTON_CLICKED,wxID_CANCEL);
+ new_event.SetEventObject( win );
+ win->GetEventHandler()->ProcessEvent( new_event );
+ }
+ }
+ else if ( event.GetKeyCode() == WXK_TAB )
+ {
+ wxNavigationKeyEvent new_event;
+ new_event.SetEventObject( this );
+ new_event.SetDirection( !event.ShiftDown() );
+ /* CTRL-TAB changes the (parent) window, i.e. switch notebook page */
+ new_event.SetWindowChange( event.ControlDown() );
+ new_event.SetCurrentFocus( this );
+ if ( !GetEventHandler()->ProcessEvent( new_event ) )
+ event.Skip() ;
+ }
+ else if ( event.GetKeyCode() == WXK_DOWN || event.GetKeyCode() == WXK_UP )
+ {
+ // perform the default key handling first
+ wxControl::OnKeyDown( event ) ;
+
+ wxCommandEvent event( wxEVT_COMMAND_LISTBOX_SELECTED, m_windowId );
+ event.SetEventObject( this );
+
+ wxArrayInt aSelections;
+ int n, count = GetSelections(aSelections);
+ if ( count > 0 )
+ {
+ n = aSelections[0];
+ if ( HasClientObjectData() )
+ event.SetClientObject( GetClientObject( n ) );
+ else if ( HasClientUntypedData() )
+ event.SetClientData( GetClientData( n ) );
+ event.SetString( GetString( n ) );
+ }
+ else
+ {
+ n = -1;
+ }
+
+ event.SetInt( n );
+
+ GetEventHandler()->ProcessEvent(event);
+ }
+ else
+ {
+ if ( event.GetTimestamp() > m_lastTypeIn + 60 )
+ m_typeIn = wxEmptyString ;
+
+ m_lastTypeIn = event.GetTimestamp() ;
+ m_typeIn += (char) event.GetKeyCode() ;
+ int line = FindString( wxT("*") + m_typeIn + wxT("*") ) ;
+ if ( line >= 0 )
+ {
+ if ( GetSelection() != line )
+ {
+ SetSelection( line ) ;
+
+ wxCommandEvent event( wxEVT_COMMAND_LISTBOX_SELECTED, m_windowId );
+ event.SetEventObject( this );
+
+ if ( HasClientObjectData() )
+ event.SetClientObject( GetClientObject( line ) );
+ else if ( HasClientUntypedData() )
+ event.SetClientData( GetClientData( line ) );
+ event.SetString( GetString( line ) );
+ event.SetInt( line );
+
+ GetEventHandler()->ProcessEvent(event);
+ }
+ }
+ }