Adds monster meta (size, type, subtype/tag, and alignment) to monster cards.
This commit is contained in:
@@ -0,0 +1,16 @@
|
||||
package com.majinnaibu.monstercards.helpers;
|
||||
|
||||
@SuppressWarnings({"BooleanMethodIsAlwaysInverted", "RedundantIfStatement"})
|
||||
public final class StringHelper {
|
||||
public static boolean isNullOrEmpty(CharSequence value) {
|
||||
if (value == null) {
|
||||
return true;
|
||||
}
|
||||
|
||||
if ("".contentEquals(value)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -1,5 +1,10 @@
|
||||
package com.majinnaibu.monstercards.models;
|
||||
|
||||
import com.majinnaibu.monstercards.helpers.StringHelper;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class Monster {
|
||||
|
||||
private String mName;
|
||||
@@ -10,4 +15,76 @@ public class Monster {
|
||||
mName = value;
|
||||
}
|
||||
|
||||
private String mSize;
|
||||
public String getSize() {
|
||||
return mSize;
|
||||
}
|
||||
public void setSize(String value) {
|
||||
mSize = value;
|
||||
}
|
||||
|
||||
private String mType;
|
||||
public String getType() {
|
||||
return mType;
|
||||
}
|
||||
public void setType(String value) {
|
||||
mType = value;
|
||||
}
|
||||
|
||||
private String mTag;
|
||||
public String getTag() {
|
||||
return mTag;
|
||||
}
|
||||
public void setTag(String value) {
|
||||
mTag = value;
|
||||
}
|
||||
|
||||
private String mAlignment;
|
||||
public String getAlignment() {
|
||||
return mAlignment;
|
||||
}
|
||||
public void setAlignment(String value) {
|
||||
mAlignment = value;
|
||||
}
|
||||
|
||||
public String getMeta() {
|
||||
StringBuilder sb = new StringBuilder();
|
||||
boolean isFirstOutput = true;
|
||||
String size = getSize();
|
||||
if (!StringHelper.isNullOrEmpty(size)) {
|
||||
sb.append(size);
|
||||
isFirstOutput = false;
|
||||
}
|
||||
|
||||
String type = getType();
|
||||
if (!StringHelper.isNullOrEmpty(type)) {
|
||||
if (!isFirstOutput) {
|
||||
sb.append(" ");
|
||||
}
|
||||
sb.append(type);
|
||||
isFirstOutput = false;
|
||||
}
|
||||
|
||||
String tag = getTag();
|
||||
if (!StringHelper.isNullOrEmpty(tag)) {
|
||||
if (!isFirstOutput) {
|
||||
sb.append(" ");
|
||||
}
|
||||
sb.append("(");
|
||||
sb.append(tag);
|
||||
sb.append(")");
|
||||
isFirstOutput = false;
|
||||
}
|
||||
|
||||
String alignment = getAlignment();
|
||||
if (!StringHelper.isNullOrEmpty(alignment)) {
|
||||
if (!isFirstOutput) {
|
||||
sb.append(", ");
|
||||
}
|
||||
sb.append(alignment);
|
||||
}
|
||||
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -15,6 +15,7 @@ import androidx.lifecycle.ViewModelProvider;
|
||||
import com.majinnaibu.monstercards.R;
|
||||
import com.majinnaibu.monstercards.models.Monster;
|
||||
|
||||
@SuppressWarnings("FieldCanBeLocal")
|
||||
public class MonsterFragment extends Fragment {
|
||||
|
||||
private MonsterViewModel monsterViewModel;
|
||||
@@ -24,7 +25,13 @@ public class MonsterFragment extends Fragment {
|
||||
|
||||
// TODO: remove this block make the monster ID a parameter to the view and get the monster from saved data (sqlite)
|
||||
Monster monster = new Monster();
|
||||
// Name
|
||||
monster.setName("Pixie");
|
||||
// Meta
|
||||
monster.setSize("tiny");
|
||||
monster.setType("fey");
|
||||
monster.setTag("");
|
||||
monster.setAlignment("neutral good");
|
||||
// END remove block
|
||||
monsterViewModel = new ViewModelProvider(this).get(MonsterViewModel.class);
|
||||
View root = inflater.inflate(R.layout.fragment_monster, container, false);
|
||||
@@ -38,6 +45,14 @@ public class MonsterFragment extends Fragment {
|
||||
}
|
||||
});
|
||||
|
||||
final TextView monsterMeta = root.findViewById(R.id.meta);
|
||||
monsterViewModel.getMeta().observe(getViewLifecycleOwner(), new Observer<String>() {
|
||||
@Override
|
||||
public void onChanged(@Nullable String s) {
|
||||
monsterMeta.setText(s);
|
||||
}
|
||||
});
|
||||
|
||||
return root;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -12,17 +12,23 @@ public class MonsterViewModel extends ViewModel {
|
||||
mMonster = null;
|
||||
mName = new MutableLiveData<>();
|
||||
mName.setValue("");
|
||||
|
||||
mMeta = new MutableLiveData<>();
|
||||
mMeta.setValue("");
|
||||
}
|
||||
|
||||
private MutableLiveData<String> mName;
|
||||
public LiveData<String> getName() {
|
||||
return mName;
|
||||
}
|
||||
private MutableLiveData<String> mMeta;
|
||||
public LiveData<String> getMeta() {
|
||||
return mMeta;
|
||||
}
|
||||
|
||||
private Monster mMonster;
|
||||
public void setMonster(Monster monster) {
|
||||
mMonster = monster;
|
||||
mName.setValue(mMonster.getName());
|
||||
mMeta.setValue(mMonster.getMeta());
|
||||
}
|
||||
}
|
||||
@@ -26,5 +26,20 @@
|
||||
app:layout_constraintTop_toTopOf="parent"
|
||||
tools:text="Pixie" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/meta"
|
||||
android:layout_width="0dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="8dp"
|
||||
android:layout_marginTop="8dp"
|
||||
android:layout_marginEnd="8dp"
|
||||
android:layout_marginBottom="8dp"
|
||||
android:textSize="15sp"
|
||||
android:textStyle="italic"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@+id/name"
|
||||
tools:text="Tiny fey, neutral good" />
|
||||
|
||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||
</ScrollView>
|
||||
Reference in New Issue
Block a user