make group head view selectable, and separate group and game selection

so that only one type can be selected at once.  Combine all three
menus into one, but only enable subsets equivalent to the old menus
depending on what's selected.  Snapshot: menus pretty much don't work.
This commit is contained in:
Eric House 2013-10-18 20:40:20 -07:00
parent 9fe34e4183
commit 43e69c7627
8 changed files with 311 additions and 257 deletions

View file

@ -1,19 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/list_group_default"
android:title="@string/list_group_default"
/>
<item android:id="@+id/list_group_rename"
android:title="@string/list_group_rename"
/>
<item android:id="@+id/list_group_moveup"
android:title="@string/list_group_moveup"
/>
<item android:id="@+id/list_group_movedown"
android:title="@string/list_group_movedown"
/>
<item android:id="@+id/list_group_delete"
android:title="@string/list_group_delete"
/>
</menu>

View file

@ -1,44 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@+id/list_item_rename"
android:title="@string/list_item_rename"
/>
<item android:id="@+id/list_item_move"
android:title="@string/list_item_move"
/>
<item android:id="@+id/list_item_reset"
android:title="@string/list_item_reset"
/>
<item android:id="@+id/list_item_new_from"
android:title="@string/list_item_new_from"
/>
<item android:id="@+id/list_item_copy"
android:title="@string/list_item_copy"
/>
<item android:title="(rest deprecated)"/>
<item android:id="@+id/list_item_delete"
android:title="@string/list_item_delete"
/>
<item android:id="@+id/list_item_config"
android:title="@string/list_item_config"
/>
<!-- <item android:id="@+id/list_item_hide" -->
<!-- android:title="@string/list_item_hide" -->
<!-- /> -->
<!-- <item android:id="@+id/list_item_move_up" -->
<!-- android:title="@string/list_item_move_up" -->
<!-- /> -->
<!-- <item android:id="@+id/list_item_move_down" -->
<!-- android:title="@string/list_item_move_down" -->
<!-- /> -->
<!-- <item android:id="@+id/list_item_move_to_top" -->
<!-- android:title="@string/list_item_move_to_top" -->
<!-- /> -->
<!-- <item android:id="@+id/list_item_move_to_bottom" -->
<!-- android:title="@string/list_item_move_to_bottom" -->
<!-- /> -->
</menu>

View file

@ -11,6 +11,13 @@
android:icon="@drawable/ic_action_delete" android:icon="@drawable/ic_action_delete"
android:showAsAction="ifRoom" android:showAsAction="ifRoom"
/> />
<item android:id="@+id/list_group_delete"
android:title="@string/list_group_delete"
android:icon="@drawable/ic_action_delete"
android:showAsAction="ifRoom"
/>
<item android:id="@+id/listl_item_config" <item android:id="@+id/listl_item_config"
android:title="@string/list_item_config" android:title="@string/list_item_config"
android:icon="@drawable/content_edit" android:icon="@drawable/content_edit"
@ -42,6 +49,38 @@
android:title="@string/gamel_menu_checkmoves" android:title="@string/gamel_menu_checkmoves"
android:icon="@drawable/stat_notify_sync" android:icon="@drawable/stat_notify_sync"
/> />
<!-- Game items -->
<item android:id="@+id/list_item_rename"
android:title="@string/list_item_rename"
/>
<item android:id="@+id/list_item_move"
android:title="@string/list_item_move"
/>
<item android:id="@+id/list_item_reset"
android:title="@string/list_item_reset"
/>
<item android:id="@+id/list_item_new_from"
android:title="@string/list_item_new_from"
/>
<item android:id="@+id/list_item_copy"
android:title="@string/list_item_copy"
/>
<!-- Group items -->
<item android:id="@+id/list_group_default"
android:title="@string/list_group_default"
/>
<item android:id="@+id/list_group_rename"
android:title="@string/list_group_rename"
/>
<item android:id="@+id/list_group_moveup"
android:title="@string/list_group_moveup"
/>
<item android:id="@+id/list_group_movedown"
android:title="@string/list_group_movedown"
/>
<!-- Debug only menuitems --> <!-- Debug only menuitems -->
<item android:id="@+id/gamel_menu_checkupdates" <item android:id="@+id/gamel_menu_checkupdates"
android:title="@string/gamel_menu_checkupdates" android:title="@string/gamel_menu_checkupdates"
@ -53,5 +92,4 @@
android:title="@string/gamel_menu_loaddb" android:title="@string/gamel_menu_loaddb"
/> />
<!-- ic_menu_archive.png -->
</menu> </menu>

View file

@ -21,6 +21,7 @@ package org.eehouse.android.xw4;
import android.content.Context; import android.content.Context;
import android.graphics.Canvas; import android.graphics.Canvas;
import android.graphics.drawable.Drawable;
import android.os.Handler; import android.os.Handler;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.widget.TextView; import android.widget.TextView;
@ -28,6 +29,8 @@ import android.widget.TextView;
class ExpiringTextView extends TextView { class ExpiringTextView extends TextView {
private ExpiringDelegate m_delegate = null; private ExpiringDelegate m_delegate = null;
private Context m_context; private Context m_context;
private Drawable m_origDrawable;
protected boolean m_selected = false;
public ExpiringTextView( Context context, AttributeSet attrs ) public ExpiringTextView( Context context, AttributeSet attrs )
{ {
@ -52,6 +55,17 @@ class ExpiringTextView extends TextView {
} }
} }
protected void toggleSelected()
{
m_selected = !m_selected;
if ( m_selected ) {
m_origDrawable = getBackground();
setBackgroundColor( XWApp.SEL_COLOR );
} else {
setBackgroundDrawable( m_origDrawable );
}
}
@Override @Override
protected void onDraw( Canvas canvas ) protected void onDraw( Canvas canvas )
{ {

View file

@ -49,11 +49,15 @@ public class GameListAdapter implements ExpandableListAdapter {
private long[] m_positions; private long[] m_positions;
public interface LoadItemCB { public interface LoadItemCB {
public void itemClicked( long rowid, GameSummary summary ); public void itemClicked( Object clicked, GameSummary summary );
public void itemToggled( long rowid, boolean selected ); public void itemToggled( Object toggled, boolean selected );
public boolean getSelected( long rowid ); public boolean getSelected( long rowid );
} }
public interface ClickHandler {
public void longClicked();
}
public GameListAdapter( Context context, ExpandableListView list, public GameListAdapter( Context context, ExpandableListView list,
Handler handler, LoadItemCB cb, long[] positions, Handler handler, LoadItemCB cb, long[] positions,
String fieldName ) String fieldName )
@ -152,9 +156,14 @@ public class GameListAdapter implements ExpandableListAdapter {
return ggi.m_name; return ggi.m_name;
} }
public void clearSelected( Set<Long> rowids ) public void clearSelectedRows( Set<Long> rowids )
{ {
deselect( rowids ); deselectRows( rowids );
}
public void clearSelectedGroups( HashSet<Integer> groups )
{
deselectGroups( groups );
} }
////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////
@ -182,7 +191,7 @@ public class GameListAdapter implements ExpandableListAdapter {
for ( long rowid : rowids ) { for ( long rowid : rowids ) {
asSet.add( rowid ); asSet.add( rowid );
} }
deselect( asSet ); deselectRows( asSet );
} }
public void onGroupExpanded( int groupPosition ) public void onGroupExpanded( int groupPosition )
@ -232,9 +241,8 @@ public class GameListAdapter implements ExpandableListAdapter {
// if ( null != convertView ) { // if ( null != convertView ) {
// DbgUtils.logf( "getGroupView gave non-null convertView" ); // DbgUtils.logf( "getGroupView gave non-null convertView" );
// } // }
GameListGroup view = (GameListGroup) GameListGroup view =
Utils.inflate(m_context, R.layout.game_list_group ); GameListGroup.makeForPosition( m_context, groupPosition, m_cb );
view.setGroupPosition( groupPosition );
if ( !isExpanded ) { if ( !isExpanded ) {
GameGroupInfo ggi = getInfoForGroup( groupPosition ); GameGroupInfo ggi = getInfoForGroup( groupPosition );
@ -364,7 +372,7 @@ public class GameListAdapter implements ExpandableListAdapter {
return gameInfo().get( getPositions()[groupPosition] ); return gameInfo().get( getPositions()[groupPosition] );
} }
private void deselect( Set<Long> rowids ) private void deselectRows( Set<Long> rowids )
{ {
GameListItem[] items = new GameListItem[rowids.size()]; GameListItem[] items = new GameListItem[rowids.size()];
getGameItemsFor( rowids, items ); getGameItemsFor( rowids, items );
@ -375,6 +383,16 @@ public class GameListAdapter implements ExpandableListAdapter {
} }
} }
private void deselectGroups( HashSet<Integer> groups )
{
groups = (HashSet<Integer>)groups.clone();
for ( Iterator<Integer>iter = groups.iterator();
iter.hasNext(); ) {
GameListGroup group = getGroupItemFor( iter.next() );
group.setSelected( false );
}
}
private void getGameItemsFor( Set<Long> rowids, GameListItem[] items ) private void getGameItemsFor( Set<Long> rowids, GameListItem[] items )
{ {
int next = 0; int next = 0;

View file

@ -23,11 +23,27 @@ package org.eehouse.android.xw4;
import android.content.Context; import android.content.Context;
import android.graphics.Canvas; import android.graphics.Canvas;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.view.View;
import org.eehouse.android.xw4.DBUtils.GameGroupInfo; import org.eehouse.android.xw4.DBUtils.GameGroupInfo;
public class GameListGroup extends ExpiringTextView { public class GameListGroup extends ExpiringTextView
implements GameListAdapter.ClickHandler
{
private int m_groupPosition; private int m_groupPosition;
private boolean m_expanded;
private GameListAdapter.LoadItemCB m_cb;
public static GameListGroup makeForPosition( Context context,
int groupPosition,
GameListAdapter.LoadItemCB cb )
{
GameListGroup result =
(GameListGroup)Utils.inflate( context, R.layout.game_list_group );
result.m_cb = cb;
result.m_groupPosition = groupPosition;
return result;
}
public GameListGroup( Context cx, AttributeSet as ) public GameListGroup( Context cx, AttributeSet as )
{ {
@ -43,4 +59,25 @@ public class GameListGroup extends ExpiringTextView {
{ {
return m_groupPosition; return m_groupPosition;
} }
public void setSelected( boolean selected )
{
// If new value and state not in sync, force change in state
if ( selected != m_selected ) {
toggleSelected();
}
}
// GameListAdapter.ClickHandler interface
public void longClicked()
{
toggleSelected();
}
protected void toggleSelected()
{
super.toggleSelected();
m_cb.itemToggled( this, m_selected );
}
} }

View file

@ -43,7 +43,7 @@ import org.eehouse.android.xw4.jni.CommsAddrRec.CommsConnType;
import org.eehouse.android.xw4.jni.GameSummary; import org.eehouse.android.xw4.jni.GameSummary;
public class GameListItem extends LinearLayout public class GameListItem extends LinearLayout
implements View.OnClickListener { implements View.OnClickListener, GameListAdapter.ClickHandler {
private static HashSet<Long> s_invalRows = new HashSet<Long>(); private static HashSet<Long> s_invalRows = new HashSet<Long>();
@ -62,6 +62,7 @@ public class GameListItem extends LinearLayout
private int m_loadingCount; private int m_loadingCount;
private int m_groupPosition; private int m_groupPosition;
private Drawable m_origDrawable; private Drawable m_origDrawable;
private boolean m_selected = false;
public GameListItem( Context cx, AttributeSet as ) public GameListItem( Context cx, AttributeSet as )
{ {
@ -71,6 +72,18 @@ public class GameListItem extends LinearLayout
m_rowid = DBUtils.ROWID_NOTFOUND; m_rowid = DBUtils.ROWID_NOTFOUND;
m_lastMoveTime = 0; m_lastMoveTime = 0;
m_loadingCount = 0; m_loadingCount = 0;
setOnClickListener( new View.OnClickListener() {
@Override
public void onClick( View v ) {
// if selected, just un-select
if ( m_selected ) {
toggleSelected();
} else if ( null != m_summary ) {
m_cb.itemClicked( this, m_summary );
}
}
} );
} }
private void init( Handler handler, long rowid, int groupPosition, private void init( Handler handler, long rowid, int groupPosition,
@ -105,7 +118,7 @@ public class GameListItem extends LinearLayout
public void setSelected( boolean selected ) public void setSelected( boolean selected )
{ {
// If new value and state not in sync, force change in state // If new value and state not in sync, force change in state
if ( selected != (null != m_origDrawable) ) { if ( selected != m_selected ) {
toggleSelected(); toggleSelected();
} }
} }
@ -214,24 +227,12 @@ public class GameListItem extends LinearLayout
return state; return state;
} }
private void setData( final GameSummary summary ) private void setData( GameSummary summary )
{ {
if ( null != summary ) { if ( null != summary ) {
TextView tview; TextView tview;
String state = setName(); String state = setName();
setOnClickListener( new View.OnClickListener() {
@Override
public void onClick( View v ) {
// if selected, just un-select
if ( null != m_origDrawable ) {
toggleSelected();
} else {
m_cb.itemClicked( m_rowid, summary );
}
}
} );
LinearLayout list = LinearLayout list =
(LinearLayout)findViewById( R.id.player_list ); (LinearLayout)findViewById( R.id.player_list );
list.removeAllViews(); list.removeAllViews();
@ -305,14 +306,14 @@ public class GameListItem extends LinearLayout
private void toggleSelected() private void toggleSelected()
{ {
if ( null == m_origDrawable ) { m_selected = !m_selected;
if ( m_selected ) {
m_origDrawable = getBackground(); m_origDrawable = getBackground();
setBackgroundColor( XWApp.SEL_COLOR ); setBackgroundColor( XWApp.SEL_COLOR );
} else { } else {
setBackgroundDrawable( m_origDrawable ); setBackgroundDrawable( m_origDrawable );
m_origDrawable = null;
} }
m_cb.itemToggled( m_rowid, null != m_origDrawable ); m_cb.itemToggled( this, m_selected );
} }
private class LoadItemTask extends AsyncTask<Void, Void, GameSummary> { private class LoadItemTask extends AsyncTask<Void, Void, GameSummary> {
@ -334,7 +335,7 @@ public class GameListItem extends LinearLayout
} }
} }
if ( m_cb.getSelected( m_rowid ) && null != m_origDrawable ) { if ( m_cb.getSelected( m_rowid ) && m_selected ) {
toggleSelected(); toggleSelected();
} }
} }
@ -372,5 +373,11 @@ public class GameListItem extends LinearLayout
// } // }
// return TextUtils.join(",", strs ); // return TextUtils.join(",", strs );
// } // }
// GameListAdapter.ClickHandler interface
public void longClicked()
{
toggleSelected();
}
} }

View file

@ -32,16 +32,15 @@ import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
import android.os.Message; import android.os.Message;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.ContextMenu;
import android.view.Menu; import android.view.Menu;
import android.view.MenuInflater; import android.view.MenuInflater;
import android.view.MenuItem; import android.view.MenuItem;
import android.view.View; import android.view.View;
import android.widget.AdapterView.OnItemLongClickListener;
import android.widget.AdapterView; import android.widget.AdapterView;
import android.widget.Button; import android.widget.Button;
import android.widget.EditText; import android.widget.EditText;
import android.widget.ExpandableListView.ExpandableListContextMenuInfo; // import android.widget.ExpandableListView.ExpandableListContextMenuInfo;
import android.widget.ExpandableListView; import android.widget.ExpandableListView;
import android.widget.LinearLayout; import android.widget.LinearLayout;
import android.widget.ListView; import android.widget.ListView;
@ -59,7 +58,8 @@ import junit.framework.Assert;
import org.eehouse.android.xw4.jni.*; import org.eehouse.android.xw4.jni.*;
public class GamesList extends XWExpandableListActivity public class GamesList extends XWExpandableListActivity
implements DBUtils.DBChangeListener, implements OnItemLongClickListener,
DBUtils.DBChangeListener,
GameListAdapter.LoadItemCB, GameListAdapter.LoadItemCB,
DictImportActivity.DownloadFinishedListener { DictImportActivity.DownloadFinishedListener {
@ -91,10 +91,33 @@ public class GamesList extends XWExpandableListActivity
DELETE_SELGAMES, DELETE_SELGAMES,
OPEN_GAME OPEN_GAME
}; };
private static final int[] DEBUGITEMS = { R.id.gamel_menu_loaddb private static final int[] DEBUGITEMS = {
R.id.gamel_menu_loaddb
, R.id.gamel_menu_storedb , R.id.gamel_menu_storedb
, R.id.gamel_menu_checkupdates , R.id.gamel_menu_checkupdates
}; };
private static final int[] NOSEL_ITEMS = {
R.id.gamel_menu_newgame
,R.id.gamel_menu_newgroup
,R.id.gamel_menu_prefs
,R.id.gamel_menu_dicts
,R.id.gamel_menu_about
,R.id.gamel_menu_email
,R.id.gamel_menu_checkmoves
};
private static final int[] ONEGAME_ITEMS = {
R.id.listl_item_config
,R.id.list_item_rename
,R.id.list_item_new_from
,R.id.list_item_copy
};
private static final int[] ONEGROUP_ITEMS = {
R.id.list_group_default
,R.id.list_group_rename
,R.id.list_group_moveup
,R.id.list_group_movedown
};
private static boolean s_firstShown = false; private static boolean s_firstShown = false;
@ -110,7 +133,8 @@ public class GamesList extends XWExpandableListActivity
private NetLaunchInfo m_netLaunchInfo; private NetLaunchInfo m_netLaunchInfo;
private GameNamer m_namer; private GameNamer m_namer;
private boolean m_gameLaunched = false; private boolean m_gameLaunched = false;
private HashSet<Long> m_selected; private HashSet<Long> m_selectedRows;
private HashSet<Integer> m_selectedGroups;
@Override @Override
protected Dialog onCreateDialog( int id ) protected Dialog onCreateDialog( int id )
@ -339,10 +363,11 @@ public class GamesList extends XWExpandableListActivity
getBundledData( savedInstanceState ); getBundledData( savedInstanceState );
m_selected = new HashSet<Long>(); m_selectedRows = new HashSet<Long>();
m_selectedGroups = new HashSet<Integer>();
setContentView(R.layout.game_list); setContentView(R.layout.game_list);
registerForContextMenu( getExpandableListView() ); ExpandableListView listview = getExpandableListView();
DBUtils.setDBChangeListener( this ); DBUtils.setDBChangeListener( this );
boolean isUpgrade = Utils.firstBootThisVersion( this ); boolean isUpgrade = Utils.firstBootThisVersion( this );
@ -354,11 +379,12 @@ public class GamesList extends XWExpandableListActivity
String field = CommonPrefs.getSummaryField( this ); String field = CommonPrefs.getSummaryField( this );
long[] positions = XWPrefs.getGroupPositions( this ); long[] positions = XWPrefs.getGroupPositions( this );
m_adapter = new GameListAdapter( this, getExpandableListView(), m_adapter = new GameListAdapter( this, listview, new Handler(),
new Handler(), this, positions, this, positions, field );
field );
setListAdapter( m_adapter ); setListAdapter( m_adapter );
m_adapter.expandGroups( getExpandableListView() ); listview.setOnItemLongClickListener( this );
m_adapter.expandGroups( listview );
NetUtils.informOfDeaths( this ); NetUtils.informOfDeaths( this );
@ -431,6 +457,16 @@ public class GamesList extends XWExpandableListActivity
} }
} }
// OnItemLongClickListener interface
public boolean onItemLongClick( AdapterView<?> parent, View view,
int position, long id ) {
boolean success = view instanceof GameListAdapter.ClickHandler;
if ( success ) {
((GameListAdapter.ClickHandler)view).longClicked();
}
return success;
}
// DBUtils.DBChangeListener interface // DBUtils.DBChangeListener interface
public void gameSaved( final long rowid, final boolean countChanged ) public void gameSaved( final long rowid, final boolean countChanged )
{ {
@ -446,33 +482,47 @@ public class GamesList extends XWExpandableListActivity
} }
// GameListAdapter.LoadItemCB interface // GameListAdapter.LoadItemCB interface
public void itemClicked( long rowid, GameSummary summary ) public void itemClicked( Object clicked, GameSummary summary )
{ {
// We need a way to let the user get back to the basic-config // We need a way to let the user get back to the basic-config
// dialog in case it was dismissed. That way it to check for // dialog in case it was dismissed. That way it to check for
// an empty room name. // an empty room name.
if ( clicked instanceof GameListItem ) {
if ( !m_gameLaunched ) { if ( !m_gameLaunched ) {
long rowid = ((GameListItem)clicked).getRowID();
showNotAgainDlgThen( R.string.not_again_newselect, showNotAgainDlgThen( R.string.not_again_newselect,
R.string.key_notagain_newselect, R.string.key_notagain_newselect,
GamesActions.OPEN_GAME.ordinal(), GamesActions.OPEN_GAME.ordinal(),
rowid, summary ); rowid, summary );
} }
} }
}
public void itemToggled( long rowid, boolean selected ) public void itemToggled( Object toggled, boolean selected )
{ {
int countBefore = m_selected.size(); if ( toggled instanceof GameListItem ) {
long rowid = ((GameListItem)toggled).getRowID();
if ( selected ) { if ( selected ) {
m_selected.add( rowid ); m_selectedRows.add( rowid );
clearSelectedGroups();
} else { } else {
m_selected.remove( rowid ); m_selectedRows.remove( rowid );
}
} else if ( toggled instanceof GameListGroup ) {
int position = ((GameListGroup)toggled).getGroupPosition();
if ( selected ) {
m_selectedGroups.add( position );
clearSelectedRows();
} else {
m_selectedGroups.remove( position );
}
} }
Utils.invalidateOptionsMenuIf( this ); Utils.invalidateOptionsMenuIf( this );
} }
public boolean getSelected( long rowid ) public boolean getSelected( long rowid )
{ {
return m_selected.contains( rowid ); return m_selectedRows.contains( rowid );
} }
// BTService.MultiEventListener interface // BTService.MultiEventListener interface
@ -548,77 +598,13 @@ public class GamesList extends XWExpandableListActivity
@Override @Override
public void onBackPressed() { public void onBackPressed() {
if ( 0 == m_selected.size() ) { if ( 0 == m_selectedRows.size() ) {
super.onBackPressed(); super.onBackPressed();
} else { } else {
clearSelected(); clearSelectedRows();
} }
} }
@Override
public void onCreateContextMenu( ContextMenu menu, View view,
ContextMenuInfo menuInfo )
{
ExpandableListView.ExpandableListContextMenuInfo info
= (ExpandableListView.ExpandableListContextMenuInfo)menuInfo;
long packedPos = info.packedPosition;
int childPos = ExpandableListView.getPackedPositionChild( packedPos );
String name;
if ( 0 <= childPos ) { // game case
MenuInflater inflater = getMenuInflater();
inflater.inflate( R.menu.games_list_item_menu, menu );
long rowid = m_adapter.getRowIDFor( packedPos );
name = GameUtils.getName( this, rowid );
} else { // group case
MenuInflater inflater = getMenuInflater();
inflater.inflate( R.menu.games_list_group_menu, menu );
int pos = ExpandableListView.getPackedPositionGroup( packedPos );
name = m_adapter.groupNames()[pos];
if ( 0 == pos ) {
Utils.setItemEnabled( menu, R.id.list_group_moveup, false );
}
if ( pos + 1 == m_adapter.getGroupCount() ) {
Utils.setItemEnabled( menu, R.id.list_group_movedown, false );
}
if ( XWPrefs.getDefaultNewGameGroup( this )
== m_adapter.getGroupIDFor( pos ) ) {
Utils.setItemEnabled( menu, R.id.list_group_default, false );
Utils.setItemEnabled( menu, R.id.list_group_delete, false );
}
}
menu.setHeaderTitle( getString( R.string.game_item_menu_titlef,
name ) );
}
@Override
public boolean onContextItemSelected( MenuItem item )
{
ExpandableListContextMenuInfo info;
try {
info = (ExpandableListContextMenuInfo)item.getMenuInfo();
} catch (ClassCastException cce) {
DbgUtils.loge( cce );
return false;
}
long packedPos = info.packedPosition;
int childPos = ExpandableListView.getPackedPositionChild( packedPos );
int groupPos = ExpandableListView.getPackedPositionGroup(packedPos);
int menuID = item.getItemId();
boolean handled;
if ( 0 <= childPos ) {
long rowid = m_adapter.getRowIDFor( groupPos, childPos );
handled = handleGameMenuItem( menuID, rowid );
} else {
handled = handleGroupMenuItem( menuID, groupPos );
}
return handled;
} // onContextItemSelected
@Override @Override
public boolean onCreateOptionsMenu( Menu menu ) public boolean onCreateOptionsMenu( Menu menu )
{ {
@ -631,22 +617,38 @@ public class GamesList extends XWExpandableListActivity
@Override @Override
public boolean onPrepareOptionsMenu( Menu menu ) public boolean onPrepareOptionsMenu( Menu menu )
{ {
int nGamesSelected = m_selectedRows.size();
int nGroupsSelected = m_selectedGroups.size();
boolean nothingSelected = 0 == (nGroupsSelected + nGamesSelected);
Assert.assertTrue( 0 == nGamesSelected || 0 == nGroupsSelected );
boolean visible = XWPrefs.getDebugEnabled( this ); boolean visible = XWPrefs.getDebugEnabled( this );
for ( int id : DEBUGITEMS ) { for ( int id : DEBUGITEMS ) {
MenuItem item = menu.findItem( id ); Utils.setItemVisible( menu, id, nothingSelected && visible );
item.setVisible( visible );
} }
if ( visible && !DBUtils.gameDBExists( this ) ) { if ( visible && !DBUtils.gameDBExists( this ) ) {
MenuItem item = menu.findItem( R.id.gamel_menu_loaddb ); Utils.setItemVisible( menu, R.id.gamel_menu_loaddb, false );
item.setVisible( false );
} }
int nSelected = m_selected.size(); for ( int id : NOSEL_ITEMS ) {
Utils.setItemVisible( menu, id, nothingSelected );
}
for ( int id : ONEGAME_ITEMS ) {
Utils.setItemVisible( menu, id, 1 == nGamesSelected );
}
for ( int id : ONEGROUP_ITEMS ) {
Utils.setItemVisible( menu, id, 1 == nGroupsSelected );
}
Utils.setItemVisible( menu, R.id.gamel_menu_newgame, 0 == nSelected ); // Multiples can be deleted
Utils.setItemVisible( menu, R.id.gamel_menu_delete, 0 < nSelected ); Utils.setItemVisible( menu, R.id.gamel_menu_delete,
Utils.setItemVisible( menu, R.id.listl_item_config, 1 == nSelected ); 0 < nGamesSelected );
Utils.setItemVisible( menu, R.id.list_group_delete,
0 < nGroupsSelected );
// multiple games can be regrouped/reset
Utils.setItemVisible( menu, R.id.list_item_move, 0 < nGroupsSelected );
Utils.setItemVisible( menu, R.id.list_item_reset, 0 < nGroupsSelected );
return super.onPrepareOptionsMenu( menu ); return super.onPrepareOptionsMenu( menu );
} }
@ -665,13 +667,13 @@ public class GamesList extends XWExpandableListActivity
break; break;
case R.id.listl_item_config: case R.id.listl_item_config:
long rowid = m_selected.iterator().next(); long rowid = m_selectedRows.iterator().next();
GameUtils.doConfig( this, rowid, GameConfig.class ); GameUtils.doConfig( this, rowid, GameConfig.class );
break; break;
case R.id.gamel_menu_delete: case R.id.gamel_menu_delete:
String msg = Utils.format( this, R.string.confirm_seldeletesf, String msg = Utils.format( this, R.string.confirm_seldeletesf,
m_selected.size() ); m_selectedRows.size() );
showConfirmThen( msg, R.string.button_delete, showConfirmThen( msg, R.string.button_delete,
GamesActions.DELETE_SELGAMES.ordinal() ); GamesActions.DELETE_SELGAMES.ordinal() );
break; break;
@ -745,13 +747,6 @@ public class GamesList extends XWExpandableListActivity
m_rowid = rowid; m_rowid = rowid;
if ( R.id.list_item_delete == menuID
|| R.id.list_item_config == menuID ) {
showOKOnlyDialog( "This menu item is going away soon. Please select"
+ " games by tapping the left icons then use"
+ " action bar icons or the screen menu to operate"
+ " on the selection." );
} else {
if ( checkWarnNoDict( m_rowid ) ) { if ( checkWarnNoDict( m_rowid ) ) {
switch ( menuID ) { switch ( menuID ) {
case R.id.list_item_reset: case R.id.list_item_reset:
@ -801,7 +796,6 @@ public class GamesList extends XWExpandableListActivity
break; break;
} }
} }
}
return handled; return handled;
} // handleGameMenuItem } // handleGameMenuItem
@ -1076,11 +1070,11 @@ public class GamesList extends XWExpandableListActivity
private void deleteSelected() private void deleteSelected()
{ {
for ( Iterator<Long> iter = m_selected.iterator(); iter.hasNext(); ) { for ( Iterator<Long> iter = m_selectedRows.iterator(); iter.hasNext(); ) {
long rowid = iter.next(); long rowid = iter.next();
GameUtils.deleteGame( this, rowid, false ); GameUtils.deleteGame( this, rowid, false );
} }
m_selected.clear(); m_selectedRows.clear();
Utils.invalidateOptionsMenuIf( this ); Utils.invalidateOptionsMenuIf( this );
NetUtils.informOfDeaths( this ); NetUtils.informOfDeaths( this );
} }
@ -1095,12 +1089,21 @@ public class GamesList extends XWExpandableListActivity
return madeGame; return madeGame;
} }
private void clearSelected() private void clearSelectedRows()
{ {
// clear any selection // clear any selection
if ( 0 < m_selected.size() ) { if ( 0 < m_selectedRows.size() ) {
m_adapter.clearSelected( m_selected ); m_adapter.clearSelectedRows( m_selectedRows );
m_selected.clear(); m_selectedRows.clear();
}
}
private void clearSelectedGroups()
{
// clear any selection
if ( 0 < m_selectedGroups.size() ) {
m_adapter.clearSelectedGroups( m_selectedGroups );
m_selectedGroups.clear();
} }
} }
@ -1119,7 +1122,7 @@ public class GamesList extends XWExpandableListActivity
if ( !m_gameLaunched ) { if ( !m_gameLaunched ) {
m_gameLaunched = true; m_gameLaunched = true;
GameUtils.launchGame( this, rowid, invited ); GameUtils.launchGame( this, rowid, invited );
clearSelected(); clearSelectedRows();
} }
} }