X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;ds=sidebyside;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fdao%2FTransactionDAO.java;h=485f65f10ecdce2ef5847bdc5bbefd35c22da3b2;hb=8c92dd30f3703556f7edda057e997283311be873;hp=0bee771368900def7e73e8b111ce7e76243e9f81;hpb=9ebf60c045fdf01d6f8d1243061e69232c2841ea;p=mobile-ledger-staging.git diff --git a/app/src/main/java/net/ktnx/mobileledger/dao/TransactionDAO.java b/app/src/main/java/net/ktnx/mobileledger/dao/TransactionDAO.java index 0bee7713..485f65f1 100644 --- a/app/src/main/java/net/ktnx/mobileledger/dao/TransactionDAO.java +++ b/app/src/main/java/net/ktnx/mobileledger/dao/TransactionDAO.java @@ -27,6 +27,7 @@ import androidx.room.Query; import androidx.room.Update; import net.ktnx.mobileledger.db.Transaction; +import net.ktnx.mobileledger.db.TransactionWithAccounts; import java.util.ArrayList; import java.util.List; @@ -42,7 +43,7 @@ public abstract class TransactionDAO extends BaseDAO { return result; } @Insert - public abstract void insertSync(Transaction item); + public abstract long insertSync(Transaction item); @Update public abstract void updateSync(Transaction item); @@ -50,6 +51,9 @@ public abstract class TransactionDAO extends BaseDAO { @Delete public abstract void deleteSync(Transaction item); + @Delete + public abstract void deleteSync(List items); + @Query("SELECT * FROM transactions") public abstract LiveData> getAll(); @@ -57,8 +61,12 @@ public abstract class TransactionDAO extends BaseDAO { // @Transaction // @Query("SELECT * FROM patterns") // List getPatternsWithAccounts(); - @Query("SELECT * FROM transactions WHERE profile = :profileUUID AND id = :id") - public abstract LiveData getById(@NonNull String profileUUID, long id); + @Query("SELECT * FROM transactions WHERE id = :id") + public abstract LiveData getById(long id); + + @androidx.room.Transaction + @Query("SELECT * FROM transactions WHERE id = :transactionId") + public abstract LiveData getByIdWithAccounts(long transactionId); @Query("SELECT DISTINCT description, CASE WHEN description_upper LIKE :term||'%%' THEN 1 " + " WHEN description_upper LIKE '%%:'||:term||'%%' THEN 2 " + @@ -68,6 +76,9 @@ public abstract class TransactionDAO extends BaseDAO { "ORDER BY ordering, description_upper, rowid ") public abstract List lookupDescriptionSync(@NonNull String term); + @Query("SELECT * from transactions WHERE profile_id = :profileId") + public abstract List allForProfileSync(long profileId); + static public class DescriptionContainer { @ColumnInfo public String description;