X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fmodel%2FTransactionListItem.java;h=550a84c5ed25d020ea0d488db89d3e634dd81582;hb=0b96f4968cd5c0b36474b94b94ec6dcf6699f60c;hp=084eaad8e8151d00af628dffcff82234fb684a2e;hpb=2c14b80572cc9199f7ed0171786a04931075b50d;p=mobile-ledger.git diff --git a/app/src/main/java/net/ktnx/mobileledger/model/TransactionListItem.java b/app/src/main/java/net/ktnx/mobileledger/model/TransactionListItem.java index 084eaad8..550a84c5 100644 --- a/app/src/main/java/net/ktnx/mobileledger/model/TransactionListItem.java +++ b/app/src/main/java/net/ktnx/mobileledger/model/TransactionListItem.java @@ -1,5 +1,5 @@ /* - * Copyright © 2020 Damyan Ivanov. + * Copyright © 2021 Damyan Ivanov. * This file is part of MoLe. * MoLe is free software: you can distribute it and/or modify it * under the term of the GNU General Public License as published by @@ -18,24 +18,32 @@ package net.ktnx.mobileledger.model; import androidx.annotation.NonNull; +import androidx.annotation.Nullable; +import net.ktnx.mobileledger.App; import net.ktnx.mobileledger.utils.SimpleDate; +import org.jetbrains.annotations.NotNull; + public class TransactionListItem { - private Type type; + private final Type type; private SimpleDate date; private boolean monthShown; private LedgerTransaction transaction; - private boolean odd; - public TransactionListItem(SimpleDate date, boolean monthShown) { + private String boldAccountName; + public TransactionListItem(@NotNull SimpleDate date, boolean monthShown) { this.type = Type.DELIMITER; this.date = date; this.monthShown = monthShown; } - public TransactionListItem(LedgerTransaction transaction, boolean isOdd) { + public TransactionListItem(@NotNull LedgerTransaction transaction, + @Nullable String boldAccountName) { this.type = Type.TRANSACTION; this.transaction = transaction; - this.odd = isOdd; + this.boldAccountName = boldAccountName; + } + public TransactionListItem() { + this.type = Type.HEADER; } @NonNull public Type getType() { @@ -43,16 +51,38 @@ public class TransactionListItem { } @NonNull public SimpleDate getDate() { - return (date != null) ? date : transaction.getDate(); + if (date != null) + return date; + if (type == Type.HEADER) + throw new IllegalStateException("Header item has no date"); + transaction.loadData(App.getDatabase()); + return transaction.getDate(); } public boolean isMonthShown() { return monthShown; } + @NotNull public LedgerTransaction getTransaction() { + if (type != Type.TRANSACTION) + throw new IllegalStateException( + String.format("Item type is not %s, but %s", Type.TRANSACTION, type)); return transaction; } - public boolean isOdd() { - return odd; + public @Nullable + String getBoldAccountName() { + return boldAccountName; + } + public enum Type { + TRANSACTION, DELIMITER, HEADER; + public static Type valueOf(int i) { + if (i == TRANSACTION.ordinal()) + return TRANSACTION; + else if (i == DELIMITER.ordinal()) + return DELIMITER; + else if (i == HEADER.ordinal()) + return HEADER; + else + throw new IllegalStateException("Unexpected value: " + i); + } } - public enum Type {TRANSACTION, DELIMITER} }