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;
|
package com.majinnaibu.monstercards.models;
|
||||||
|
|
||||||
|
import com.majinnaibu.monstercards.helpers.StringHelper;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class Monster {
|
public class Monster {
|
||||||
|
|
||||||
private String mName;
|
private String mName;
|
||||||
@@ -10,4 +15,76 @@ public class Monster {
|
|||||||
mName = value;
|
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.R;
|
||||||
import com.majinnaibu.monstercards.models.Monster;
|
import com.majinnaibu.monstercards.models.Monster;
|
||||||
|
|
||||||
|
@SuppressWarnings("FieldCanBeLocal")
|
||||||
public class MonsterFragment extends Fragment {
|
public class MonsterFragment extends Fragment {
|
||||||
|
|
||||||
private MonsterViewModel monsterViewModel;
|
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)
|
// 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();
|
Monster monster = new Monster();
|
||||||
|
// Name
|
||||||
monster.setName("Pixie");
|
monster.setName("Pixie");
|
||||||
|
// Meta
|
||||||
|
monster.setSize("tiny");
|
||||||
|
monster.setType("fey");
|
||||||
|
monster.setTag("");
|
||||||
|
monster.setAlignment("neutral good");
|
||||||
// END remove block
|
// END remove block
|
||||||
monsterViewModel = new ViewModelProvider(this).get(MonsterViewModel.class);
|
monsterViewModel = new ViewModelProvider(this).get(MonsterViewModel.class);
|
||||||
View root = inflater.inflate(R.layout.fragment_monster, container, false);
|
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;
|
return root;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,17 +12,23 @@ public class MonsterViewModel extends ViewModel {
|
|||||||
mMonster = null;
|
mMonster = null;
|
||||||
mName = new MutableLiveData<>();
|
mName = new MutableLiveData<>();
|
||||||
mName.setValue("");
|
mName.setValue("");
|
||||||
|
mMeta = new MutableLiveData<>();
|
||||||
|
mMeta.setValue("");
|
||||||
}
|
}
|
||||||
|
|
||||||
private MutableLiveData<String> mName;
|
private MutableLiveData<String> mName;
|
||||||
public LiveData<String> getName() {
|
public LiveData<String> getName() {
|
||||||
return mName;
|
return mName;
|
||||||
}
|
}
|
||||||
|
private MutableLiveData<String> mMeta;
|
||||||
|
public LiveData<String> getMeta() {
|
||||||
|
return mMeta;
|
||||||
|
}
|
||||||
|
|
||||||
private Monster mMonster;
|
private Monster mMonster;
|
||||||
public void setMonster(Monster monster) {
|
public void setMonster(Monster monster) {
|
||||||
mMonster = monster;
|
mMonster = monster;
|
||||||
mName.setValue(mMonster.getName());
|
mName.setValue(mMonster.getName());
|
||||||
|
mMeta.setValue(mMonster.getMeta());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -26,5 +26,20 @@
|
|||||||
app:layout_constraintTop_toTopOf="parent"
|
app:layout_constraintTop_toTopOf="parent"
|
||||||
tools:text="Pixie" />
|
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>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
</ScrollView>
|
</ScrollView>
|
||||||
Reference in New Issue
Block a user