.
This commit is contained in:
parent
a7f51909cd
commit
ef5392bb3a
@ -14,11 +14,14 @@ import androidx.compose.foundation.layout.fillMaxSize
|
||||
import androidx.compose.foundation.layout.fillMaxWidth
|
||||
import androidx.compose.foundation.layout.padding
|
||||
import androidx.compose.foundation.layout.requiredHeight
|
||||
import androidx.compose.foundation.layout.size
|
||||
import androidx.compose.foundation.layout.wrapContentHeight
|
||||
import androidx.compose.foundation.layout.wrapContentSize
|
||||
import androidx.compose.foundation.layout.wrapContentWidth
|
||||
import androidx.compose.foundation.shape.CircleShape
|
||||
import androidx.compose.foundation.shape.RoundedCornerShape
|
||||
import androidx.compose.material.icons.Icons
|
||||
import androidx.compose.material.icons.filled.Add
|
||||
import androidx.compose.material.icons.filled.DateRange
|
||||
import androidx.compose.material.icons.filled.List
|
||||
import androidx.compose.material3.Button
|
||||
@ -29,6 +32,7 @@ import androidx.compose.material3.ExperimentalMaterial3Api
|
||||
import androidx.compose.material3.Icon
|
||||
import androidx.compose.material3.IconButton
|
||||
import androidx.compose.material3.MaterialTheme
|
||||
import androidx.compose.material3.OutlinedButton
|
||||
import androidx.compose.material3.OutlinedTextField
|
||||
import androidx.compose.material3.Surface
|
||||
import androidx.compose.material3.Text
|
||||
@ -77,11 +81,17 @@ fun HeaderCard(modifier: Modifier = Modifier, balance: String, onCategoryButton:
|
||||
.padding(16.dp)
|
||||
) {
|
||||
Column() {
|
||||
IconButton(onClick = {
|
||||
onCategoryButton()
|
||||
}) {
|
||||
OutlinedButton(
|
||||
modifier= Modifier.size(50.dp),
|
||||
shape = CircleShape,
|
||||
border= BorderStroke(1.dp, Color(0xffc6c6c6)),
|
||||
contentPadding = PaddingValues(0.dp),
|
||||
onClick = {
|
||||
onCategoryButton()
|
||||
}
|
||||
) {
|
||||
Icon(
|
||||
imageVector = Icons.Filled.List,
|
||||
imageVector = Icons.Filled.Add,
|
||||
contentDescription = "Add to list", // Provide a meaningful description for accessibility
|
||||
tint = MaterialTheme.colorScheme.onSurface // Optional: Adjust the tint as needed
|
||||
)
|
||||
@ -219,6 +229,7 @@ fun LayoutMediaText(modifier: Modifier = Modifier, name: String, date: String, a
|
||||
}
|
||||
Box(
|
||||
modifier = Modifier
|
||||
.weight(1f)
|
||||
.fillMaxHeight()
|
||||
.wrapContentWidth() // Allow the Box to wrap its content width
|
||||
.padding(start = 16.dp), // Add some padding to separate from the Column
|
||||
|
@ -37,7 +37,7 @@ fun AddCategory(
|
||||
) {
|
||||
|
||||
var name by remember { mutableStateOf("") }
|
||||
var selectedIconIndex by remember { mutableStateOf(0) } // Store index of selected icon
|
||||
var selectedIconIndex by remember { mutableStateOf(-1) } // Store index of selected icon
|
||||
var expanded by remember { mutableStateOf(false) } // Controls dropdown visibility
|
||||
|
||||
Column(
|
||||
|
@ -18,18 +18,13 @@ data class CategoryUIState(val category: CategoryEntity = CategoryEntity(0,"",0)
|
||||
|
||||
|
||||
class EditCategoryViewModel(private val savedStateHandle: SavedStateHandle, private val entryRepository: EntryRepository) : ViewModel() {
|
||||
|
||||
|
||||
private val categoryId: Int = checkNotNull(savedStateHandle["categoryId"])
|
||||
|
||||
|
||||
var categoryUi by mutableStateOf(CategoryUIState())
|
||||
private set
|
||||
var deletePossible by mutableStateOf(false)
|
||||
var redirect by mutableStateOf(false)
|
||||
|
||||
|
||||
|
||||
init {
|
||||
viewModelScope.launch {
|
||||
val category = withContext(Dispatchers.IO) {
|
||||
|
BIN
MockupAdd.png
BIN
MockupAdd.png
Binary file not shown.
Before Width: | Height: | Size: 208 KiB |
BIN
MockupEdit.png
BIN
MockupEdit.png
Binary file not shown.
Before Width: | Height: | Size: 255 KiB |
BIN
MockupStart.png
BIN
MockupStart.png
Binary file not shown.
Before Width: | Height: | Size: 434 KiB |
80
README.md
80
README.md
@ -29,10 +29,80 @@ Like:
|
||||
- Budget-Conscious Individuals
|
||||
- Small Business Owners
|
||||
|
||||
|
||||
### Mockups
|
||||
|
||||
data:image/s3,"s3://crabby-images/9c7ae/9c7ae0e6df5da7c0b26e990ddb9394f40153cd9b" alt="Mockup of Start Screen"
|
||||
data:image/s3,"s3://crabby-images/c2fc6/c2fc6f624e7cfa9a1a94c9ba753635ccdc0ac700" alt="Mockup of Add Screen"
|
||||
data:image/s3,"s3://crabby-images/3e949/3e949b04071c0f10121fc678d876ae4161ae2468" alt="Mockup of Edit Screen"
|
||||
data:image/s3,"s3://crabby-images/05c1b/05c1b2cb66ff19f7d6411c650e724f79c460ed0f" alt="Userflow"
|
||||
data:image/s3,"s3://crabby-images/c4f81/c4f81c767c1496fecc7c2f75a38917a415578b85" alt="Mockup"
|
||||
data:image/s3,"s3://crabby-images/05c1b/05c1b2cb66ff19f7d6411c650e724f79c460ed0f" alt="Userflow"
|
||||
|
||||
## Usability Testing Plan
|
||||
### Experimental Questions & Variables
|
||||
1. Question: Does the user have any major issue while navigating the app?
|
||||
- IV: App navigation design (e.g., layout, menu structure, or usability features).
|
||||
- DV: User-reported issues or difficulties while navigating.
|
||||
- Methods: SEQ Question
|
||||
|
||||
2. Question: Does the user find Categories useful?
|
||||
- IV: Presence or design of the Categories feature.
|
||||
- DV: User perception of usefulness (e.g., measured via survey or rating).
|
||||
- Method: Likert scale How useful was it?
|
||||
3. Question: Does the user find Categories?
|
||||
- IV: Visibility or accessibility of the Categories feature.
|
||||
- DV: User success in locating or using Categories.
|
||||
- Method: Task Completion Testing
|
||||
|
||||
4. Question: Does the icon selection affect user satisfaction?
|
||||
- IV: Icon design or selection (e.g., different icon styles or clarity).
|
||||
- DV: User satisfaction (e.g., measured via survey or rating).
|
||||
- Method: Open Question
|
||||
|
||||
5. Question: How long does it take for a user to add a Category?
|
||||
- IV: Process or interface for adding a Category (e.g., number of steps, clarity of instructions).
|
||||
- DV: Time taken to complete the task.
|
||||
- Method: Time till completion
|
||||
|
||||
6. Question: How long does it take for a user to add a Transaction?
|
||||
- IV: Process or interface for adding a Transaction (e.g., simplicity, number of fields).
|
||||
- DV: Time taken to complete the task.
|
||||
- Method: Time till completion
|
||||
|
||||
### Heuristic Evaluation
|
||||
|
||||
1. Visibility of System Status
|
||||
- Issue: Users may not be immediately aware of changes to their balance after adding or editing a transaction, as there is no clear feedback.
|
||||
- Recommendations: Implement a visual or auditory feedback system (e.g., a confirmation message or animation or redirect to the Balance overview) to inform users when their balance updates.
|
||||
|
||||
2. Match Between System and the Real World
|
||||
- Issues: None
|
||||
- Recommendations: None
|
||||
|
||||
3. User Control and Freedom
|
||||
- Issues: Users might want to create their own categories rather than use the predefined ones.
|
||||
- Recommendations: Introduce a feature to add and delete your own categories.
|
||||
4. Consistency and Standards
|
||||
- Issues: The "Your Balance" and the name of the transaction do not share the same font
|
||||
- Recommendations: Standardize all texts to use the same font, and color scheme for a cohesive user experience.
|
||||
|
||||
5. Error Prevention
|
||||
- Issues: Users might enter invalid data, such as symbols as the amount, without receiving a warning, leading to potential errors.
|
||||
- Recommendations: Add validation checks and warnings to prevent users from entering incorrect data, ensuring errors are caught before submission.
|
||||
|
||||
6. Recognition Rather Than Recall
|
||||
- Issues: Users may need to remember details about past transactions, such as categories or dates, which could increase cognitive load.
|
||||
- Recommendations: Display a detailed transaction history with categories and dates visible at all times, reducing the need for users to recall information.
|
||||
|
||||
7. Flexibility and Efficiency of Use
|
||||
- Issues: Users may find it time-consuming to navigate through multiple screens or steps to perform common tasks, such as adding or editing transactions.
|
||||
- Recommendations: Ensure that all frequently used actions, like adding or deleting transactions, can be completed in as few steps as possible, with clear and accessible buttons for quick access.
|
||||
8. Aesthetic and Minimalist Design
|
||||
- Issues: The interface might include too many visual elements or colors, which could distract users from focusing on their primary tasks, such as managing transactions or checking their balance.
|
||||
- Recommendations: Ensure that the design remains clean and focused by using a limited color palette and removing any unnecessary decorative elements, keeping the interface visually simple and task-oriented.
|
||||
|
||||
9. Help Users Recognize, Diagnose, and Recover from Errors
|
||||
- Issues: Error messages may not clearly explain what went wrong or how to fix it, leaving users confused.
|
||||
- Recommendations: Provide detailed error messages in plain language, including actionable steps to resolve the issue.
|
||||
|
||||
10. Help and Documentation
|
||||
- Issues: Help and Documentation may be important and nice to have but out of scope for this version of the design.
|
||||
- Recommendations: For now, focus on maintaining the clarity and simplicity of the current help documentation. If these advanced features are considered in future updates, ensure that corresponding help resources are developed to support them.
|
||||
|
||||
|
||||
|
BIN
mockup.png
Normal file
BIN
mockup.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 759 KiB |
Loading…
Reference in New Issue
Block a user