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