Skip to content

Commit

Permalink
Add Income tags
Browse files Browse the repository at this point in the history
  • Loading branch information
PawanHegde committed Oct 15, 2022
1 parent 3117e04 commit 8e9b4a5
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 7 deletions.
34 changes: 30 additions & 4 deletions Expenso/Configs.swift
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ let CURRENCY_LIST = ["₹", "$", "€", "¥", "£", "¢", "₭"]
let TRANS_TYPE_INCOME = "income"
let TRANS_TYPE_EXPENSE = "expense"

// Transaction tags
// Expense Transaction tags
let TRANS_TAG_TRANSPORT = "transport"
let TRANS_TAG_FOOD = "food"
let TRANS_TAG_HOUSING = "housing"
Expand All @@ -39,11 +39,20 @@ let TRANS_TAG_MEDICAL = "medical"
let TRANS_TAG_SAVINGS = "savings"
let TRANS_TAG_PERSONAL = "personal"
let TRANS_TAG_ENTERTAINMENT = "entertainment"
let TRANS_TAG_OTHERS = "others"
let TRANS_TAG_UTILITIES = "utilities"

// Income Transaction tags
let TRANS_TAG_SALARY = "salary"
let TRANS_TAG_CASHBACK = "cashback"
let TRANS_TAG_INVESTMENT_RETURNS = "investment_returns"
let TRANS_TAG_SALE = "sale"

// Common Transaction tags
let TRANS_TAG_OTHERS = "others"

func getTransTagIcon(transTag: String) -> String {
switch transTag {
// Expenses
case TRANS_TAG_TRANSPORT: return "trans_type_transport"
case TRANS_TAG_FOOD: return "trans_type_food"
case TRANS_TAG_HOUSING: return "trans_type_housing"
Expand All @@ -52,14 +61,22 @@ func getTransTagIcon(transTag: String) -> String {
case TRANS_TAG_SAVINGS: return "trans_type_savings"
case TRANS_TAG_PERSONAL: return "trans_type_personal"
case TRANS_TAG_ENTERTAINMENT: return "trans_type_entertainment"
case TRANS_TAG_OTHERS: return "trans_type_others"
case TRANS_TAG_UTILITIES: return "trans_type_utilities"

// Incomes
// TODO: Add icon sets for every income tag
case TRANS_TAG_SALARY: return "trans_type_savings"
case TRANS_TAG_CASHBACK: return "trans_type_savings"
case TRANS_TAG_INVESTMENT_RETURNS: return "trans_type_savings"
case TRANS_TAG_SALE: return "trans_type_savings"

default: return "trans_type_others"
}
}

func getTransTagTitle(transTag: String) -> String {
switch transTag {
// Expenses
case TRANS_TAG_TRANSPORT: return "Transport"
case TRANS_TAG_FOOD: return "Food"
case TRANS_TAG_HOUSING: return "Housing"
Expand All @@ -68,8 +85,17 @@ func getTransTagTitle(transTag: String) -> String {
case TRANS_TAG_SAVINGS: return "Savings"
case TRANS_TAG_PERSONAL: return "Personal"
case TRANS_TAG_ENTERTAINMENT: return "Entertainment"
case TRANS_TAG_OTHERS: return "Others"
case TRANS_TAG_UTILITIES: return "Utilities"

// Incomes
case TRANS_TAG_SALARY: return "Salary"
case TRANS_TAG_CASHBACK: return "Cashback"
case TRANS_TAG_INVESTMENT_RETURNS: return "Investment Returns"
case TRANS_TAG_SALE: return "Sale"

// Common
case TRANS_TAG_OTHERS: return "Others"

default: return "Unknown"
}
}
Expand Down
17 changes: 14 additions & 3 deletions Expenso/Screens/AddExpense/AddExpenseView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,10 @@ struct AddExpenseView: View {
DropdownOption(key: TRANS_TYPE_EXPENSE, val: "Expense")
]

let tagOptions = [
let expenseTagOptions = [
DropdownOption(key: TRANS_TAG_TRANSPORT, val: "Transport"),
DropdownOption(key: TRANS_TAG_FOOD, val: "Food"),
DropdownOption(key: TRANS_TAG_GROCERIES, val: "Groceries"),
DropdownOption(key: TRANS_TAG_HOUSING, val: "Housing"),
DropdownOption(key: TRANS_TAG_INSURANCE, val: "Insurance"),
DropdownOption(key: TRANS_TAG_MEDICAL, val: "Medical"),
Expand All @@ -35,6 +36,14 @@ struct AddExpenseView: View {
DropdownOption(key: TRANS_TAG_UTILITIES, val: "Utilities")
]

let incomeTagOptions = [
DropdownOption(key: TRANS_TAG_SALARY, val: "Salary"),
DropdownOption(key: TRANS_TAG_CASHBACK, val: "Cashback"),
DropdownOption(key: TRANS_TAG_INVESTMENT_RETURNS, val: "Investment Returns"),
DropdownOption(key: TRANS_TAG_OTHERS, val: "Others"),
DropdownOption(key: TRANS_TAG_SALE, val: "Sale"),
]

var body: some View {
NavigationView {
ZStack {
Expand Down Expand Up @@ -88,8 +97,10 @@ struct AddExpenseView: View {
}

DropdownButton(shouldShowDropdown: $viewModel.showTagDrop, displayText: $viewModel.tagTitle,
options: tagOptions, mainColor: Color.text_primary_color,
backgroundColor: Color.secondary_color, cornerRadius: 4, buttonHeight: 50) { key in
options: viewModel.selectedType == TRANS_TYPE_INCOME ? incomeTagOptions : expenseTagOptions,
mainColor: Color.text_primary_color, backgroundColor: Color.secondary_color,
cornerRadius: 4, buttonHeight: 50) { key in
let tagOptions = viewModel.selectedType == TRANS_TYPE_INCOME ? incomeTagOptions : expenseTagOptions
let selectedObj = tagOptions.filter({ $0.key == key }).first
if let object = selectedObj {
viewModel.tagTitle = object.val
Expand Down

0 comments on commit 8e9b4a5

Please sign in to comment.