Skip to content

Commit

Permalink
Don't let the user set internal categories
Browse files Browse the repository at this point in the history
The user mustn't set "internal categories" (Income, Spending, Split,
Transfer, Uncategorized). Therefore they mustn't show up in the
"Categories" window, or the menu of the category button, or when
doing autocomplete.

The new function IsInternalCategory() checks if a category is "internal".
  • Loading branch information
humdingerb committed Jul 10, 2024
1 parent cfb0a5b commit 8fd71fd
Show file tree
Hide file tree
Showing 6 changed files with 35 additions and 14 deletions.
8 changes: 2 additions & 6 deletions src/CategoryBox.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ CategoryBoxFilter::KeyFilter(const int32& key, const int32& mod)

BString autocomplete = acc->AutocompleteCategory(string.String());

if (autocomplete.CountChars() > 0) {
if (autocomplete.CountChars() > 0 && !IsInternalCategory(autocomplete.String())) {
BMessage automsg(M_CATEGORY_AUTOCOMPLETE);
automsg.AddInt32("start", strlen(TextControl()->Text()) + 1);
automsg.AddString("string", autocomplete.String());
Expand Down Expand Up @@ -101,11 +101,7 @@ CategoryBox::Validate(void)
return false;
}

if (category.ICompare(B_TRANSLATE_CONTEXT("Income", "CommonTerms")) == 0
|| category.ICompare(B_TRANSLATE_CONTEXT("Spending", "CommonTerms")) == 0
|| category.ICompare(B_TRANSLATE_CONTEXT("Split", "CommonTerms")) == 0
|| category.ICompare(B_TRANSLATE_CONTEXT("Transfer", "CommonTerms")) == 0
|| category.ICompare(B_TRANSLATE_CONTEXT("Uncategorized", "CommonTerms")) == 0) {
if (IsInternalCategory(category.String())) {
ShowAlert(B_TRANSLATE("Can't use this category name"),
B_TRANSLATE(
"CapitalBe uses 'Income', 'Spending', 'Split', 'Transfer', and 'Uncategorized' "
Expand Down
5 changes: 4 additions & 1 deletion src/CategoryButton.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,10 @@ CategoryButton::ShowPopUpMenu()
while (!query.eof()) {
int expense = query.getIntField(1);
BString name = DeescapeIllegalCharacters(query.getStringField(0));

if (IsInternalCategory(name.String())) {
query.nextRow();
continue;
}
BMessage* msg = new BMessage(M_CATEGORY_CHOSEN);
msg->AddString("category", name);

Expand Down
12 changes: 6 additions & 6 deletions src/CategoryWindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -214,11 +214,7 @@ CategoryView::MessageReceived(BMessage* msg)
|| msg->FindBool("expense", &expense) != B_OK)
break;

if (name.ICompare(B_TRANSLATE_CONTEXT("Income", "CommonTerms")) == 0
|| name.ICompare(B_TRANSLATE_CONTEXT("Spending", "CommonTerms")) == 0
|| name.ICompare(B_TRANSLATE_CONTEXT("Split", "CommonTerms")) == 0
|| name.ICompare(B_TRANSLATE_CONTEXT("Transfer", "CommonTerms")) == 0
|| name.ICompare(B_TRANSLATE_CONTEXT("Uncategorized", "CommonTerms")) == 0) {
if (IsInternalCategory(name.String())) {
ShowAlert(B_TRANSLATE("Can't use this category name"),
B_TRANSLATE(
"CapitalBe uses 'Income', 'Spending', 'Split', 'Transfer', and "
Expand Down Expand Up @@ -303,9 +299,13 @@ CategoryView::RefreshCategoryList(void)
CppSQLite3Query query = gDatabase.DBQuery(
"SELECT * FROM categorylist ORDER BY name DESC", "CategoryView::CategoryView");
while (!query.eof()) {
int expense = query.getIntField(1);
BString name = query.getStringField(0);
if (IsInternalCategory(name.String())) {
query.nextRow();
continue;
}

int expense = query.getIntField(1);
if (expense == SPENDING)
fListView->AddUnder(new CategoryItem(name.String()), fSpendingItem);
else if (expense == INCOME)
Expand Down
20 changes: 20 additions & 0 deletions src/Database.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#include "Database.h"
#include <Catalog.h>
#include <Directory.h>
#include <Entry.h>
#include <stdio.h>
Expand Down Expand Up @@ -1595,3 +1596,22 @@ Database::DeescapeDatabase(void)

return B_OK;
}

bool
IsInternalCategory(const char* category)
{
const char* internal_categories[] = {
B_TRANSLATE_CONTEXT("Income", "CommonTerms"),
B_TRANSLATE_CONTEXT("Spending", "CommonTerms"),
B_TRANSLATE_CONTEXT("Split", "CommonTerms"),
B_TRANSLATE_CONTEXT("Transfer", "CommonTerms"),
B_TRANSLATE_CONTEXT("Uncategorized", "CommonTerms"),
NULL
};

for (int32 i = 0; internal_categories[i] != NULL; i++) {
if (strcasecmp(internal_categories[i], category) == 0)
return true;
}
return false;
}
2 changes: 2 additions & 0 deletions src/Database.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
#include <Locker.h>
#include <String.h>
#include <time.h>

#include "Account.h"
#include "CBLocale.h"
#include "CppSQLite3.h"
Expand All @@ -22,6 +23,7 @@ enum category_type {
};

BString AccountTypeToString(const AccountType& type);
bool IsInternalCategory(const char* category);

class Database : public Notifier {
public:
Expand Down
2 changes: 1 addition & 1 deletion src/SplitView.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -170,7 +170,7 @@ SplitView::SplitView(const char* name, const TransactionData& trans, const int32

if (fTransaction.CountCategories() > 1
|| strcmp(fTransaction.NameAt(0), B_TRANSLATE_CONTEXT("Split", "CommonTerms")) == 0) {
fCategory->SetText(B_TRANSLATE("Split transaction"));
fCategory->SetText(B_TRANSLATE_CONTEXT("Split transaction", "CommonTerms"));
fStartExpanded = true;
}

Expand Down

0 comments on commit 8fd71fd

Please sign in to comment.