diff --git a/MiceAndMysticsTracker/src/main/AndroidManifest.xml b/MiceAndMysticsTracker/src/main/AndroidManifest.xml index 20ca41e016958ab8bef16aed025f55b1a0f177bd..7f29f01a473992e1c14cf57c56c470b552827b84 100644 --- a/MiceAndMysticsTracker/src/main/AndroidManifest.xml +++ b/MiceAndMysticsTracker/src/main/AndroidManifest.xml @@ -25,6 +25,9 @@ android:name="android.support.PARENT_ACTIVITY" android:value="com.eyecreate.miceandmystics.miceandmystics.CampaignActivity" /> + + diff --git a/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/CampaignDetailsActivity.java b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/CampaignDetailsActivity.java index 3085bc4a7a0b2e62b2ff1074a4934165acda4070..47d4dde20870bdfe6cd54ed265f1cb2121748f76 100644 --- a/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/CampaignDetailsActivity.java +++ b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/CampaignDetailsActivity.java @@ -3,7 +3,9 @@ package com.eyecreate.miceandmystics.miceandmystics; import android.app.AlertDialog; import android.content.Context; import android.content.DialogInterface; +import android.content.Intent; import android.os.Bundle; +import android.os.PersistableBundle; import android.support.v7.widget.LinearLayoutManager; import android.view.*; import android.widget.ArrayAdapter; @@ -25,11 +27,20 @@ public class CampaignDetailsActivity extends RecyclerViewActivity { protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setTitle("Game Details"); - campaign = MiceAndMysticsApplication.getRealmInstance().where(Campaign.class).equalTo("campaignName",getIntent().getStringExtra("campaignName")).findFirst(); + if(getIntent().hasExtra("campaignName")) { + campaign = MiceAndMysticsApplication.getRealmInstance().where(Campaign.class).equalTo("campaignName",getIntent().getStringExtra("campaignName")).findFirst(); + } else if(savedInstanceState.containsKey("campaignName")) { + campaign = MiceAndMysticsApplication.getRealmInstance().where(Campaign.class).equalTo("campaignName",savedInstanceState.getString("campaignName")).findFirst(); + } setLayoutManager(new LinearLayoutManager(this)); setAdapter(new CampaignDetailsAdapter(campaign)); } + @Override + public void onSaveInstanceState(Bundle outState, PersistableBundle outPersistentState) { + super.onSaveInstanceState(outState, outPersistentState); + outState.putString("campaignName", campaign.getCampaignName()); + } @Override public boolean onCreateOptionsMenu(Menu menu) { @@ -50,31 +61,38 @@ public class CampaignDetailsActivity extends RecyclerViewActivity { newCharacterDialog(); return true; } else if (id == R.id.action_add_player) { - newPlayerDialog(); + newPlayerDialog(this); + return true; + } else if (id == R.id.action_manage_players) { + Intent managePlayers = new Intent(this,PlayerManagerActivity.class); + startActivity(managePlayers); return true; } return super.onOptionsItemSelected(item); } - public void newPlayerDialog() { - LayoutInflater inflator = (LayoutInflater)(new ContextThemeWrapper(this, R.style.dialogTheme)).getSystemService(Context.LAYOUT_INFLATER_SERVICE); + public static void newPlayerDialog(final Context ctx) { + LayoutInflater inflator = (LayoutInflater)(new ContextThemeWrapper(ctx, R.style.dialogTheme)).getSystemService(Context.LAYOUT_INFLATER_SERVICE); final View dialogView = inflator.inflate(R.layout.dialog_new_player, null, false); final EditText playerEdit = ((EditText)dialogView.findViewById(R.id.player_name)); - AlertDialog addDialog = new AlertDialog.Builder(this,R.style.dialogTheme) + AlertDialog addDialog = new AlertDialog.Builder(ctx,R.style.dialogTheme) .setMessage("Please name the new player:") .setView(dialogView) .setPositiveButton("Create", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialogInterface, int i) { - if (playerEdit.getText().length()>0) { + RealmResults matchingPlayers = MiceAndMysticsApplication.getRealmInstance().where(Player.class).equalTo("playerName", playerEdit.getText().toString()).findAll(); + if (playerEdit.getText().length() > 0 && matchingPlayers.size() == 0) { MiceAndMysticsApplication.getRealmInstance().beginTransaction(); Player player = MiceAndMysticsApplication.getRealmInstance().createObject(Player.class); player.setPlayerName(playerEdit.getText().toString()); MiceAndMysticsApplication.getRealmInstance().copyToRealmOrUpdate(player); MiceAndMysticsApplication.getRealmInstance().commitTransaction(); - } else { - Toast.makeText(CampaignDetailsActivity.this,"Can not have a blank name!",Toast.LENGTH_LONG).show(); + } else if (playerEdit.getText().length() == 0) { + Toast.makeText(ctx, "Can not have a blank name!", Toast.LENGTH_LONG).show(); + } else if (matchingPlayers.size() > 0) { + Toast.makeText(ctx, "Can not have same name as another player!", Toast.LENGTH_LONG).show(); } } }) @@ -82,6 +100,12 @@ public class CampaignDetailsActivity extends RecyclerViewActivity { addDialog.show(); } + @Override + protected void onResume() { + super.onResume(); + getAdapter().notifyDataSetChanged(); + } + public void newCharacterDialog() { LayoutInflater inflator = (LayoutInflater)(new ContextThemeWrapper(this, R.style.dialogTheme)).getSystemService(Context.LAYOUT_INFLATER_SERVICE); final View dialogView = inflator.inflate(R.layout.dialog_new_character, null, false); diff --git a/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/PlayerManagerActivity.java b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/PlayerManagerActivity.java new file mode 100644 index 0000000000000000000000000000000000000000..0dffc2a91267e8d357330aa5d8cc213720b8fbc6 --- /dev/null +++ b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/PlayerManagerActivity.java @@ -0,0 +1,43 @@ +package com.eyecreate.miceandmystics.miceandmystics; + +import android.os.Bundle; +import android.support.v7.widget.LinearLayoutManager; +import android.view.Menu; +import android.view.MenuItem; +import com.eyecreate.miceandmystics.miceandmystics.adapters.PlayerManagerAdapter; + +public class PlayerManagerActivity extends RecyclerViewActivity { + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setTitle("Manage Players"); + getSupportActionBar().setDisplayHomeAsUpEnabled(true); + setLayoutManager(new LinearLayoutManager(this)); + setAdapter(new PlayerManagerAdapter()); + } + + @Override + public boolean onCreateOptionsMenu(Menu menu) { + // Inflate the menu; this adds items to the action bar if it is present. + getMenuInflater().inflate(R.menu.menu_player_manager, menu); + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + // Handle action bar item clicks here. The action bar will + // automatically handle clicks on the Home/Up button, so long + // as you specify a parent activity in AndroidManifest.xml. + int id = item.getItemId(); + + //noinspection SimplifiableIfStatement + if (id == R.id.action_add_player) { + CampaignDetailsActivity.newPlayerDialog(this); + return true; + } else if (id == android.R.id.home) { + finish(); + } + + return super.onOptionsItemSelected(item); + } +} diff --git a/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/adapters/PlayerManagerAdapter.java b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/adapters/PlayerManagerAdapter.java new file mode 100644 index 0000000000000000000000000000000000000000..4d252b612b2b19d0b9f53a556249bc0d17fd660e --- /dev/null +++ b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/adapters/PlayerManagerAdapter.java @@ -0,0 +1,92 @@ +package com.eyecreate.miceandmystics.miceandmystics.adapters; + +import android.app.AlertDialog; +import android.content.Context; +import android.content.DialogInterface; +import android.support.v7.widget.RecyclerView; +import android.view.LayoutInflater; +import android.view.ViewGroup; +import com.eyecreate.miceandmystics.miceandmystics.MiceAndMysticsApplication; +import com.eyecreate.miceandmystics.miceandmystics.R; +import com.eyecreate.miceandmystics.miceandmystics.model.*; +import com.eyecreate.miceandmystics.miceandmystics.model.Character; +import com.eyecreate.miceandmystics.miceandmystics.viewholders.PlayerViewHolder; +import io.realm.RealmResults; + +import java.util.Iterator; + +public class PlayerManagerAdapter extends RecyclerView.Adapter { + + LayoutInflater inflater; + RealmResults playerList; + + public PlayerManagerAdapter() { + playerList = MiceAndMysticsApplication.getRealmInstance().where(Player.class).findAll(); + } + + @Override + public PlayerViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { + if(inflater == null) inflater = (LayoutInflater)parent.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); + return new PlayerViewHolder(inflater.inflate(R.layout.item_player,parent,false),this); + } + + @Override + public void onBindViewHolder(PlayerViewHolder holder, int position) { + holder.bindHolder(playerList.get(position)); + } + + @Override + public int getItemCount() { + return playerList.size(); + } + + public void removePlayer(final String playerName,Context ctx) { + //This part checks to see if any characters are attached to this player. + final RealmResults playerCharacters = MiceAndMysticsApplication.getRealmInstance().where(com.eyecreate.miceandmystics.miceandmystics.model.Character.class) + .equalTo("controllingPlayer.playerName", playerName).findAll(); + if(playerCharacters.size()>0) { + AlertDialog removeDialog = new AlertDialog.Builder(ctx,R.style.dialogTheme) + .setMessage("Removing player "+playerName+" must first remove all characters owned by player. Do you want to continue still?") + .setNegativeButton("No", new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialogInterface, int i) { + + } + }) + .setPositiveButton("Yes", new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialogInterface, int i) { + for(Iterator iter = playerCharacters.iterator();playerCharacters.iterator().hasNext();) { + CampaignDetailsAdapter.removeCharacterFromDB((Character)iter.next()); + } + MiceAndMysticsApplication.getRealmInstance().beginTransaction(); + MiceAndMysticsApplication.getRealmInstance().where(Player.class).equalTo("playerName",playerName).findFirst().removeFromRealm(); + MiceAndMysticsApplication.getRealmInstance().commitTransaction(); + notifyDataSetChanged(); + } + }) + .create(); + removeDialog.show(); + } else { + AlertDialog removeDialog = new AlertDialog.Builder(ctx, R.style.dialogTheme) + .setMessage("Do you want to remove player: " + playerName + "?") + .setNegativeButton("No", new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialogInterface, int i) { + + } + }) + .setPositiveButton("Yes", new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialogInterface, int i) { + MiceAndMysticsApplication.getRealmInstance().beginTransaction(); + MiceAndMysticsApplication.getRealmInstance().where(Player.class).equalTo("playerName",playerName).findFirst().removeFromRealm(); + MiceAndMysticsApplication.getRealmInstance().commitTransaction(); + notifyDataSetChanged(); + } + }) + .create(); + removeDialog.show(); + } + } +} diff --git a/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/viewholders/PlayerViewHolder.java b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/viewholders/PlayerViewHolder.java new file mode 100644 index 0000000000000000000000000000000000000000..971286f81493cdec575e5ed632a9acab34311e12 --- /dev/null +++ b/MiceAndMysticsTracker/src/main/java/com/eyecreate/miceandmystics/miceandmystics/viewholders/PlayerViewHolder.java @@ -0,0 +1,31 @@ +package com.eyecreate.miceandmystics.miceandmystics.viewholders; + +import android.support.v7.widget.RecyclerView; +import android.view.View; +import android.widget.TextView; +import com.eyecreate.miceandmystics.miceandmystics.R; +import com.eyecreate.miceandmystics.miceandmystics.adapters.PlayerManagerAdapter; +import com.eyecreate.miceandmystics.miceandmystics.model.Player; + +public class PlayerViewHolder extends RecyclerView.ViewHolder implements View.OnLongClickListener { + + TextView playerName; + PlayerManagerAdapter adapter; + + public PlayerViewHolder(View itemView,PlayerManagerAdapter adapter) { + super(itemView); + this.adapter = adapter; + playerName = (TextView)itemView.findViewById(R.id.player_name); + itemView.setOnLongClickListener(this); + } + + public void bindHolder(Player player) { + playerName.setText(player.getPlayerName()); + } + + @Override + public boolean onLongClick(View view) { + adapter.removePlayer(playerName.getText().toString(),view.getContext()); + return true; + } +} diff --git a/MiceAndMysticsTracker/src/main/res/layout/item_player.xml b/MiceAndMysticsTracker/src/main/res/layout/item_player.xml new file mode 100644 index 0000000000000000000000000000000000000000..69bca3ed3ebf643728e8e5ace8e8670417af986d --- /dev/null +++ b/MiceAndMysticsTracker/src/main/res/layout/item_player.xml @@ -0,0 +1,27 @@ + + + + + + + + \ No newline at end of file diff --git a/MiceAndMysticsTracker/src/main/res/menu/menu_campaign_details.xml b/MiceAndMysticsTracker/src/main/res/menu/menu_campaign_details.xml index 05c4ad06dff9274a9957d8f3688738848e475e37..f5e2317db99b127f45c1005440a5b76a16a34bc6 100644 --- a/MiceAndMysticsTracker/src/main/res/menu/menu_campaign_details.xml +++ b/MiceAndMysticsTracker/src/main/res/menu/menu_campaign_details.xml @@ -9,5 +9,13 @@ + + diff --git a/MiceAndMysticsTracker/src/main/res/menu/menu_player_manager.xml b/MiceAndMysticsTracker/src/main/res/menu/menu_player_manager.xml new file mode 100644 index 0000000000000000000000000000000000000000..72b54b8c4279508a597f648382e6a8126dfb2ba8 --- /dev/null +++ b/MiceAndMysticsTracker/src/main/res/menu/menu_player_manager.xml @@ -0,0 +1,8 @@ + + + + \ No newline at end of file diff --git a/MiceAndMysticsTracker/src/main/res/mipmap-xxhdpi/ic_menu_friendslist.png b/MiceAndMysticsTracker/src/main/res/mipmap-xxhdpi/ic_menu_friendslist.png new file mode 100644 index 0000000000000000000000000000000000000000..920d687e5cd985e91d2da3e1622f48230a9670c4 Binary files /dev/null and b/MiceAndMysticsTracker/src/main/res/mipmap-xxhdpi/ic_menu_friendslist.png differ diff --git a/MiceAndMysticsTracker/src/main/res/mipmap-xxhdpi/ic_menu_star.png b/MiceAndMysticsTracker/src/main/res/mipmap-xxhdpi/ic_menu_star.png new file mode 100644 index 0000000000000000000000000000000000000000..0b9af8e104d00b65271602ec21c0bd88c4474428 Binary files /dev/null and b/MiceAndMysticsTracker/src/main/res/mipmap-xxhdpi/ic_menu_star.png differ