Adds edit basic info screen with most string fields.
Cleans up fonts/margins on edit screens. Makes the EditMonsterViewModel shared between edit monster fragments.
This commit is contained in:
		| @@ -0,0 +1,95 @@ | |||||||
|  | package com.majinnaibu.monstercards.ui.editmonster; | ||||||
|  |  | ||||||
|  | import android.os.Bundle; | ||||||
|  | import android.view.LayoutInflater; | ||||||
|  | import android.view.View; | ||||||
|  | import android.view.ViewGroup; | ||||||
|  | import android.widget.EditText; | ||||||
|  |  | ||||||
|  | import androidx.fragment.app.Fragment; | ||||||
|  | import androidx.lifecycle.ViewModelProvider; | ||||||
|  | import androidx.navigation.NavBackStackEntry; | ||||||
|  | import androidx.navigation.NavController; | ||||||
|  | import androidx.navigation.Navigation; | ||||||
|  |  | ||||||
|  | import com.majinnaibu.monstercards.R; | ||||||
|  | import com.majinnaibu.monstercards.ui.MCFragment; | ||||||
|  | import com.majinnaibu.monstercards.utils.Logger; | ||||||
|  | import com.majinnaibu.monstercards.utils.TextChangedListener; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * A simple {@link Fragment} subclass. | ||||||
|  |  */ | ||||||
|  | public class EditBasicInfoFragment extends MCFragment { | ||||||
|  |     private EditMonsterViewModel mViewModel; | ||||||
|  |     private ViewHolder mHolder; | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public View onCreateView(LayoutInflater inflater, ViewGroup container, | ||||||
|  |                              Bundle savedInstanceState) { | ||||||
|  |         NavController navController = Navigation.findNavController(requireActivity(), R.id.nav_host_fragment); | ||||||
|  |         NavBackStackEntry backStackEntry = navController.getBackStackEntry(R.id.edit_monster_navigation); | ||||||
|  |         mViewModel = new ViewModelProvider(backStackEntry).get(EditMonsterViewModel.class); | ||||||
|  |  | ||||||
|  |         // Inflate the layout for this fragment | ||||||
|  |         View root = inflater.inflate(R.layout.fragment_edit_basic_info, container, false); | ||||||
|  |  | ||||||
|  |         mHolder = new ViewHolder(root); | ||||||
|  |         mHolder.name.setText(mViewModel.getName().getValue()); | ||||||
|  |         mHolder.name.addTextChangedListener(new TextChangedListener((TextChangedListener.OnTextChangedCallback) (s, start, before, count) -> { | ||||||
|  |             mViewModel.setName(s.toString()); | ||||||
|  |             Logger.logDebug(String.format("Monster Name changed to %s", mViewModel.getName().getValue())); | ||||||
|  |         })); | ||||||
|  |  | ||||||
|  |         mHolder.size.setText(mViewModel.getSize().getValue()); | ||||||
|  |         mHolder.size.addTextChangedListener(new TextChangedListener((TextChangedListener.OnTextChangedCallback) (s, start, before, count) -> { | ||||||
|  |             mViewModel.setSize(s.toString()); | ||||||
|  |             Logger.logDebug(String.format("Monster Size changed to %s", mViewModel.getSize().getValue())); | ||||||
|  |         })); | ||||||
|  |  | ||||||
|  |         mHolder.type.setText(mViewModel.getType().getValue()); | ||||||
|  |         mHolder.type.addTextChangedListener(new TextChangedListener((TextChangedListener.OnTextChangedCallback) (s, start, before, count) -> { | ||||||
|  |             mViewModel.setType(s.toString()); | ||||||
|  |             Logger.logDebug(String.format("Monster Type changed to %s", mViewModel.getType().getValue())); | ||||||
|  |         })); | ||||||
|  |  | ||||||
|  |         mHolder.subtype.setText(mViewModel.getSubtype().getValue()); | ||||||
|  |         mHolder.subtype.addTextChangedListener(new TextChangedListener((TextChangedListener.OnTextChangedCallback) (s, start, before, count) -> { | ||||||
|  |             mViewModel.setSubtype(s.toString()); | ||||||
|  |             Logger.logDebug(String.format("Monster Subtype changed to %s", mViewModel.getSubtype().getValue())); | ||||||
|  |         })); | ||||||
|  |  | ||||||
|  |         mHolder.alignment.setText(mViewModel.getAlignment().getValue()); | ||||||
|  |         mHolder.alignment.addTextChangedListener(new TextChangedListener((TextChangedListener.OnTextChangedCallback) (s, start, before, count) -> { | ||||||
|  |             mViewModel.setAlignment(s.toString()); | ||||||
|  |             Logger.logDebug(String.format("Monster Alignment changed to %s", mViewModel.getAlignment().getValue())); | ||||||
|  |         })); | ||||||
|  |  | ||||||
|  |         mHolder.customHitPoints.setText(mViewModel.getCustomHitPoints().getValue()); | ||||||
|  |         mHolder.customHitPoints.addTextChangedListener((new TextChangedListener((TextChangedListener.OnTextChangedCallback) (s, start, before, count) -> { | ||||||
|  |             mViewModel.setCustomHitPoints(s.toString()); | ||||||
|  |             Logger.logDebug(String.format("Monster Custom Hit Points changed to %s", mViewModel.getCustomHitPoints().getValue())); | ||||||
|  |         }))); | ||||||
|  |  | ||||||
|  |         return root; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static class ViewHolder { | ||||||
|  |         private final EditText name; | ||||||
|  |         private final EditText size; | ||||||
|  |         private final EditText type; | ||||||
|  |         private final EditText subtype; | ||||||
|  |         private final EditText alignment; | ||||||
|  |         private final EditText customHitPoints; | ||||||
|  |  | ||||||
|  |         ViewHolder(View root) { | ||||||
|  |             name = root.findViewById(R.id.name); | ||||||
|  |             size = root.findViewById(R.id.size); | ||||||
|  |             type = root.findViewById(R.id.type); | ||||||
|  |             subtype = root.findViewById(R.id.subtype); | ||||||
|  |             alignment = root.findViewById(R.id.alignment); | ||||||
|  |             customHitPoints = root.findViewById(R.id.customHitPoints); | ||||||
|  |             // TODO: add hitDice, hasCustomHitPoints, and customHitPoints | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -9,6 +9,10 @@ import android.widget.TextView; | |||||||
| import androidx.annotation.NonNull; | import androidx.annotation.NonNull; | ||||||
| import androidx.annotation.Nullable; | import androidx.annotation.Nullable; | ||||||
| import androidx.lifecycle.ViewModelProvider; | import androidx.lifecycle.ViewModelProvider; | ||||||
|  | import androidx.navigation.NavBackStackEntry; | ||||||
|  | import androidx.navigation.NavController; | ||||||
|  | import androidx.navigation.NavDirections; | ||||||
|  | import androidx.navigation.Navigation; | ||||||
|  |  | ||||||
| import com.majinnaibu.monstercards.R; | import com.majinnaibu.monstercards.R; | ||||||
| import com.majinnaibu.monstercards.data.MonsterRepository; | import com.majinnaibu.monstercards.data.MonsterRepository; | ||||||
| @@ -39,17 +43,24 @@ public class EditMonsterFragment extends MCFragment { | |||||||
|         assert arguments != null; |         assert arguments != null; | ||||||
|         UUID monsterId = UUID.fromString(MonsterDetailFragmentArgs.fromBundle(arguments).getMonsterId()); |         UUID monsterId = UUID.fromString(MonsterDetailFragmentArgs.fromBundle(arguments).getMonsterId()); | ||||||
|  |  | ||||||
|  |         NavController navController = Navigation.findNavController(requireActivity(), R.id.nav_host_fragment); | ||||||
|  |         NavBackStackEntry backStackEntry = navController.getBackStackEntry(R.id.edit_monster_navigation); | ||||||
|  |         mViewModel = new ViewModelProvider(backStackEntry).get(EditMonsterViewModel.class); | ||||||
|  |  | ||||||
|         View root = inflater.inflate(R.layout.fragment_edit_monster, container, false); |         View root = inflater.inflate(R.layout.fragment_edit_monster, container, false); | ||||||
|         mHolder = new ViewHolder(root); |         mHolder = new ViewHolder(root); | ||||||
|         requireAppCompatActivity().getSupportActionBar().setTitle(getString(R.string.title_edit_monster, getString(R.string.default_monster_name))); |         requireAppCompatActivity().getSupportActionBar().setTitle(getString(R.string.title_edit_monster, getString(R.string.default_monster_name))); | ||||||
|  |  | ||||||
|         // TODO: Show a loading spinner until we have the monster loaded. |         // TODO: Show a loading spinner until we have the monster loaded. | ||||||
|  |         if (mViewModel.hasError() || !mViewModel.hasLoaded() || !mViewModel.getMonsterId().getValue().equals(monsterId)) { | ||||||
|             repository.getMonster(monsterId).toObservable() |             repository.getMonster(monsterId).toObservable() | ||||||
|                     .firstOrError() |                     .firstOrError() | ||||||
|                     .subscribe(new DisposableSingleObserver<Monster>() { |                     .subscribe(new DisposableSingleObserver<Monster>() { | ||||||
|                         @Override |                         @Override | ||||||
|                         public void onSuccess(@io.reactivex.rxjava3.annotations.NonNull Monster monster) { |                         public void onSuccess(@io.reactivex.rxjava3.annotations.NonNull Monster monster) { | ||||||
|                             Logger.logDebug(String.format("Monster loaded: %s", monster.name)); |                             Logger.logDebug(String.format("Monster loaded: %s", monster.name)); | ||||||
|  |                             mViewModel.setHasLoaded(true); | ||||||
|  |                             mViewModel.setHasError(false); | ||||||
|                             mViewModel.copyFromMonster(monster); |                             mViewModel.copyFromMonster(monster); | ||||||
|                             requireAppCompatActivity().getSupportActionBar().setTitle(getString(R.string.title_edit_monster, monster.name)); |                             requireAppCompatActivity().getSupportActionBar().setTitle(getString(R.string.title_edit_monster, monster.name)); | ||||||
|                             dispose(); |                             dispose(); | ||||||
| @@ -59,13 +70,19 @@ public class EditMonsterFragment extends MCFragment { | |||||||
|                         public void onError(@io.reactivex.rxjava3.annotations.NonNull Throwable e) { |                         public void onError(@io.reactivex.rxjava3.annotations.NonNull Throwable e) { | ||||||
|                             // TODO: Show an error state. |                             // TODO: Show an error state. | ||||||
|                             Logger.logError(e); |                             Logger.logError(e); | ||||||
|  |                             mViewModel.setHasError(true); | ||||||
|  |                             mViewModel.setErrorMessage(e.toString()); | ||||||
|                             dispose(); |                             dispose(); | ||||||
|                         } |                         } | ||||||
|                     }); |                     }); | ||||||
|  |         } | ||||||
|         mHolder.basicInfoButton.setOnClickListener(v -> { |         mHolder.basicInfoButton.setOnClickListener(v -> { | ||||||
|             // TODO: Navigate to the EditBasicInfo fragment |             // TODO: Navigate to the EditBasicInfo fragment | ||||||
|             Logger.logDebug("Basic Info clicked"); |             Logger.logDebug("Basic Info clicked"); | ||||||
|  |             NavDirections action = EditMonsterFragmentDirections.actionEditMonsterFragmentToEditBasicInfoFragment(); | ||||||
|  |             View view = getView(); | ||||||
|  |             assert view != null; | ||||||
|  |             Navigation.findNavController(view).navigate(action); | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         return root; |         return root; | ||||||
| @@ -74,8 +91,6 @@ public class EditMonsterFragment extends MCFragment { | |||||||
|     @Override |     @Override | ||||||
|     public void onActivityCreated(@Nullable Bundle savedInstanceState) { |     public void onActivityCreated(@Nullable Bundle savedInstanceState) { | ||||||
|         super.onActivityCreated(savedInstanceState); |         super.onActivityCreated(savedInstanceState); | ||||||
|         mViewModel = new ViewModelProvider(this).get(EditMonsterViewModel.class); |  | ||||||
|         // TODO: Use the ViewModel |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static class ViewHolder { |     private static class ViewHolder { | ||||||
|   | |||||||
| @@ -10,22 +10,40 @@ import com.majinnaibu.monstercards.models.Monster; | |||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
| public class EditMonsterViewModel extends ViewModel { | public class EditMonsterViewModel extends ViewModel { | ||||||
|     private MutableLiveData<String> mName; |     private final MutableLiveData<String> mName; | ||||||
|     private MutableLiveData<UUID> mMonsterId; |     private final MutableLiveData<UUID> mMonsterId; | ||||||
|  |     private final MutableLiveData<String> mErrorMessage; | ||||||
|  |     private final MutableLiveData<Boolean> mHasError; | ||||||
|  |     private final MutableLiveData<Boolean> mHasLoaded; | ||||||
|  |     private final MutableLiveData<String> mSize; | ||||||
|  |     private final MutableLiveData<String> mType; | ||||||
|  |     private final MutableLiveData<String> mSubtype; | ||||||
|  |     private final MutableLiveData<String> mAlignment; | ||||||
|  |     private final MutableLiveData<String> mCustomHitPoints; | ||||||
|  |  | ||||||
|     public EditMonsterViewModel() { |     public EditMonsterViewModel() { | ||||||
|  |  | ||||||
|         mName = new MutableLiveData<>(); |         mName = new MutableLiveData<>(""); | ||||||
|         mName.setValue(""); |         mMonsterId = new MutableLiveData<>(UUID.randomUUID()); | ||||||
|  |         mErrorMessage = new MutableLiveData<>(""); | ||||||
|         mMonsterId = new MutableLiveData<>(); |         mHasError = new MutableLiveData<>(false); | ||||||
|         mMonsterId.setValue(UUID.randomUUID()); |         mHasLoaded = new MutableLiveData<>(false); | ||||||
|  |         mSize = new MutableLiveData<>(""); | ||||||
|  |         mType = new MutableLiveData<>(""); | ||||||
|  |         mSubtype = new MutableLiveData<>(""); | ||||||
|  |         mAlignment = new MutableLiveData<>(""); | ||||||
|  |         mCustomHitPoints = new MutableLiveData<>(""); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void copyFromMonster(Monster monster) { |     public void copyFromMonster(Monster monster) { | ||||||
|         // TODO: copy from monster to other fields |         // TODO: copy from monster to other fields | ||||||
|         mMonsterId.setValue(monster.id); |         mMonsterId.setValue(monster.id); | ||||||
|         mName.setValue(monster.name); |         mName.setValue(monster.name); | ||||||
|  |         mSize.setValue(monster.size); | ||||||
|  |         mType.setValue(monster.type); | ||||||
|  |         mSubtype.setValue(monster.subtype); | ||||||
|  |         mAlignment.setValue(monster.alignment); | ||||||
|  |         mCustomHitPoints.setValue(monster.customHPDescription); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public LiveData<String> getName() { |     public LiveData<String> getName() { | ||||||
| @@ -36,4 +54,80 @@ public class EditMonsterViewModel extends ViewModel { | |||||||
|         mName.setValue(name); |         mName.setValue(name); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public LiveData<UUID> getMonsterId() { | ||||||
|  |         return mMonsterId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<String> getErrorMessage() { | ||||||
|  |         return mErrorMessage; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setErrorMessage(@NonNull String errorMessage) { | ||||||
|  |         mErrorMessage.setValue(errorMessage); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<Boolean> getHasError() { | ||||||
|  |         return mHasError; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setHasError(@NonNull Boolean hasError) { | ||||||
|  |         mHasError.setValue(hasError); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean hasError() { | ||||||
|  |         return getHasError().getValue(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<Boolean> getHasLoaded() { | ||||||
|  |         return mHasLoaded; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setHasLoaded(@NonNull Boolean hasLoaded) { | ||||||
|  |         mHasLoaded.setValue(hasLoaded); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean hasLoaded() { | ||||||
|  |         return getHasLoaded().getValue(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<String> getSize() { | ||||||
|  |         return mSize; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setSize(@NonNull String size) { | ||||||
|  |         mSize.setValue(size); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<String> getType() { | ||||||
|  |         return mType; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setType(@NonNull String type) { | ||||||
|  |         mType.setValue(type); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<String> getSubtype() { | ||||||
|  |         return mSubtype; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setSubtype(@NonNull String subType) { | ||||||
|  |         mSubtype.setValue(subType); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<String> getAlignment() { | ||||||
|  |         return mAlignment; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setAlignment(@NonNull String alignment) { | ||||||
|  |         mAlignment.setValue(alignment); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public LiveData<String> getCustomHitPoints() { | ||||||
|  |         return mCustomHitPoints; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setCustomHitPoints(String customHitPoints) { | ||||||
|  |         mCustomHitPoints.setValue(customHitPoints); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										106
									
								
								app/src/main/res/layout/fragment_edit_basic_info.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								app/src/main/res/layout/fragment_edit_basic_info.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,106 @@ | |||||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||||
|  | <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" | ||||||
|  |     xmlns:tools="http://schemas.android.com/tools" | ||||||
|  |     android:layout_width="match_parent" | ||||||
|  |     android:layout_height="match_parent" | ||||||
|  |     tools:context=".ui.editmonster.EditBasicInfoFragment"> | ||||||
|  |  | ||||||
|  |     <LinearLayout | ||||||
|  |         android:layout_width="match_parent" | ||||||
|  |         android:layout_height="wrap_content" | ||||||
|  |         android:orientation="vertical"> | ||||||
|  |  | ||||||
|  |         <com.google.android.material.textfield.TextInputLayout | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="wrap_content" | ||||||
|  |             android:layout_margin="@dimen/text_margin"> | ||||||
|  |  | ||||||
|  |             <com.google.android.material.textfield.TextInputEditText | ||||||
|  |                 android:id="@+id/name" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:hint="@string/label_name" | ||||||
|  |                 android:importantForAutofill="no" | ||||||
|  |                 android:inputType="textCapWords" | ||||||
|  |                 tools:text="John Doe" /> | ||||||
|  |         </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|  |         <com.google.android.material.textfield.TextInputLayout | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="wrap_content" | ||||||
|  |             android:layout_margin="@dimen/text_margin"> | ||||||
|  |  | ||||||
|  |             <com.google.android.material.textfield.TextInputEditText | ||||||
|  |                 android:id="@+id/size" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:hint="@string/label_size" | ||||||
|  |                 android:importantForAutofill="no" | ||||||
|  |                 android:inputType="text" | ||||||
|  |                 tools:text="big" /> | ||||||
|  |         </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|  |         <com.google.android.material.textfield.TextInputLayout | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="wrap_content" | ||||||
|  |             android:layout_margin="@dimen/text_margin"> | ||||||
|  |  | ||||||
|  |             <com.google.android.material.textfield.TextInputEditText | ||||||
|  |                 android:id="@+id/type" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:hint="@string/label_type" | ||||||
|  |                 android:importantForAutofill="no" | ||||||
|  |                 android:inputType="text" | ||||||
|  |                 tools:text="fiend" /> | ||||||
|  |         </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|  |         <com.google.android.material.textfield.TextInputLayout | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="wrap_content" | ||||||
|  |             android:layout_margin="@dimen/text_margin"> | ||||||
|  |  | ||||||
|  |             <com.google.android.material.textfield.TextInputEditText | ||||||
|  |                 android:id="@+id/subtype" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:hint="@string/label_subtype" | ||||||
|  |                 android:importantForAutofill="no" | ||||||
|  |                 android:inputType="text" | ||||||
|  |                 tools:text="any race" /> | ||||||
|  |         </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|  |         <com.google.android.material.textfield.TextInputLayout | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="wrap_content" | ||||||
|  |             android:layout_margin="@dimen/text_margin"> | ||||||
|  |  | ||||||
|  |             <com.google.android.material.textfield.TextInputEditText | ||||||
|  |                 android:id="@+id/alignment" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:hint="@string/label_alignment" | ||||||
|  |                 android:importantForAutofill="no" | ||||||
|  |                 android:inputType="text" | ||||||
|  |                 tools:text="Chaotic Stupid" /> | ||||||
|  |         </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |  | ||||||
|  |         <!-- Hit Dice (int) --> | ||||||
|  |  | ||||||
|  |         <!-- Has ustom HP (boolean) --> | ||||||
|  |  | ||||||
|  |         <com.google.android.material.textfield.TextInputLayout | ||||||
|  |             android:layout_width="match_parent" | ||||||
|  |             android:layout_height="wrap_content" | ||||||
|  |             android:layout_margin="@dimen/text_margin"> | ||||||
|  |  | ||||||
|  |             <com.google.android.material.textfield.TextInputEditText | ||||||
|  |                 android:id="@+id/customHitPoints" | ||||||
|  |                 android:layout_width="match_parent" | ||||||
|  |                 android:layout_height="wrap_content" | ||||||
|  |                 android:hint="@string/label_custom_hp" | ||||||
|  |                 android:importantForAutofill="no" | ||||||
|  |                 android:inputType="text" /> | ||||||
|  |         </com.google.android.material.textfield.TextInputLayout> | ||||||
|  |     </LinearLayout> | ||||||
|  | </ScrollView> | ||||||
| @@ -6,7 +6,6 @@ | |||||||
|     android:layout_height="match_parent"> |     android:layout_height="match_parent"> | ||||||
|  |  | ||||||
|     <LinearLayout |     <LinearLayout | ||||||
|         android:id="@+id/list" |  | ||||||
|         android:layout_width="match_parent" |         android:layout_width="match_parent" | ||||||
|         android:layout_height="wrap_content" |         android:layout_height="wrap_content" | ||||||
|         android:divider="?android:attr/dividerVertical" |         android:divider="?android:attr/dividerVertical" | ||||||
| @@ -21,6 +20,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_basic_info" |             android:text="@string/label_basic_info" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -29,6 +29,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_armor" |             android:text="@string/label_armor" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -37,6 +38,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_speed" |             android:text="@string/label_speed" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -45,6 +47,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_ability_scores" |             android:text="@string/label_ability_scores" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -53,6 +56,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_saving_throws" |             android:text="@string/label_saving_throws" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -61,6 +65,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_skills" |             android:text="@string/label_skills" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -69,6 +74,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_condition_immunities" |             android:text="@string/label_condition_immunities" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -77,6 +83,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_damage_immunities" |             android:text="@string/label_damage_immunities" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -85,6 +92,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_damage_resistances" |             android:text="@string/label_damage_resistances" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -93,6 +101,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_damage_vulnerabilities" |             android:text="@string/label_damage_vulnerabilities" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -101,6 +110,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_senses" |             android:text="@string/label_senses" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -109,6 +119,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_languages" |             android:text="@string/label_languages" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -117,6 +128,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_challenge_rating" |             android:text="@string/label_challenge_rating" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -125,6 +137,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_abilities" |             android:text="@string/label_abilities" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -133,6 +146,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_actions" |             android:text="@string/label_actions" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -141,6 +155,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_reactions" |             android:text="@string/label_reactions" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -149,6 +164,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_legendary_actions" |             android:text="@string/label_legendary_actions" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -157,6 +173,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_lair_actions" |             android:text="@string/label_lair_actions" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|         <TextView |         <TextView | ||||||
| @@ -165,6 +182,7 @@ | |||||||
|             android:layout_height="wrap_content" |             android:layout_height="wrap_content" | ||||||
|             android:layout_margin="@dimen/text_margin" |             android:layout_margin="@dimen/text_margin" | ||||||
|             android:text="@string/label_regional_actions" |             android:text="@string/label_regional_actions" | ||||||
|  |             android:textSize="@dimen/text_h4_size" | ||||||
|             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> |             app:drawableEndCompat="@drawable/ic_chevron_right_24" /> | ||||||
|  |  | ||||||
|     </LinearLayout> |     </LinearLayout> | ||||||
|   | |||||||
| @@ -55,8 +55,15 @@ | |||||||
|             app:argType="string" /> |             app:argType="string" /> | ||||||
|         <action |         <action | ||||||
|             android:id="@+id/action_navigation_monster_to_editMonsterFragment" |             android:id="@+id/action_navigation_monster_to_editMonsterFragment" | ||||||
|             app:destination="@id/editMonsterFragment" /> |             app:destination="@id/edit_monster_navigation" /> | ||||||
|     </fragment> |     </fragment> | ||||||
|  |     <navigation | ||||||
|  |         android:id="@+id/edit_monster_navigation" | ||||||
|  |         app:startDestination="@id/editMonsterFragment"> | ||||||
|  |         <argument | ||||||
|  |             android:name="monster_id" | ||||||
|  |             app:argType="string" /> | ||||||
|  |  | ||||||
|         <fragment |         <fragment | ||||||
|             android:id="@+id/editMonsterFragment" |             android:id="@+id/editMonsterFragment" | ||||||
|             android:name="com.majinnaibu.monstercards.ui.editmonster.EditMonsterFragment" |             android:name="com.majinnaibu.monstercards.ui.editmonster.EditMonsterFragment" | ||||||
| @@ -65,6 +72,15 @@ | |||||||
|             <argument |             <argument | ||||||
|                 android:name="monster_id" |                 android:name="monster_id" | ||||||
|                 app:argType="string" /> |                 app:argType="string" /> | ||||||
|  |             <action | ||||||
|  |                 android:id="@+id/action_editMonsterFragment_to_editBasicInfoFragment" | ||||||
|  |                 app:destination="@id/editBasicInfoFragment" /> | ||||||
|         </fragment> |         </fragment> | ||||||
|  |         <fragment | ||||||
|  |             android:id="@+id/editBasicInfoFragment" | ||||||
|  |             android:name="com.majinnaibu.monstercards.ui.editmonster.EditBasicInfoFragment" | ||||||
|  |             android:label="fragment_edit_basic_info" | ||||||
|  |             tools:layout="@layout/fragment_edit_basic_info" /> | ||||||
|  |     </navigation> | ||||||
|  |  | ||||||
| </navigation> | </navigation> | ||||||
| @@ -2,5 +2,6 @@ | |||||||
|     <!-- Default screen margins, per the Android Design guidelines. --> |     <!-- Default screen margins, per the Android Design guidelines. --> | ||||||
|     <dimen name="text_margin">16dp</dimen> |     <dimen name="text_margin">16dp</dimen> | ||||||
|     <dimen name="fab_margin">16dp</dimen> |     <dimen name="fab_margin">16dp</dimen> | ||||||
|  |     <dimen name="text_h4_size">20sp</dimen> | ||||||
|  |  | ||||||
| </resources> | </resources> | ||||||
| @@ -38,4 +38,10 @@ | |||||||
|     <string name="default_monster_name">Unnamed Monster</string> |     <string name="default_monster_name">Unnamed Monster</string> | ||||||
|     <string name="snackbar_failed_to_create_monster">Failed to create monster</string> |     <string name="snackbar_failed_to_create_monster">Failed to create monster</string> | ||||||
|     <string name="snackbar_monster_created">%1$s created</string> |     <string name="snackbar_monster_created">%1$s created</string> | ||||||
|  |     <string name="label_name">Name</string> | ||||||
|  |     <string name="label_size">Size</string> | ||||||
|  |     <string name="label_type">Type</string> | ||||||
|  |     <string name="label_subtype">Subtype</string> | ||||||
|  |     <string name="label_alignment">Alignment</string> | ||||||
|  |     <string name="label_custom_hp">Custom HP</string> | ||||||
| </resources> | </resources> | ||||||
		Reference in New Issue
	
	Block a user