X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fdao%2FAccountDAO.java;h=3b401b669ef9e303e2b91d1aa5348acf05cdd0bf;hp=bb8d4ec2333d9e34a647d83c28ded648cdfd1762;hb=8098a8b37a4331b9faf6cf50a51a0d7aa9677421;hpb=55e1029ad80ef8eb223413d9cc633efefb1b68ac diff --git a/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java b/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java index bb8d4ec2..3b401b66 100644 --- a/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java +++ b/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java @@ -24,9 +24,11 @@ import androidx.room.Dao; import androidx.room.Delete; import androidx.room.Insert; import androidx.room.Query; +import androidx.room.Transaction; import androidx.room.Update; import net.ktnx.mobileledger.db.Account; +import net.ktnx.mobileledger.db.AccountWithAmounts; import java.util.ArrayList; import java.util.List; @@ -50,8 +52,18 @@ public abstract class AccountDAO extends BaseDAO { @Delete public abstract void deleteSync(Account item); - @Query("SELECT * FROM accounts") - public abstract LiveData> getAll(); + @Delete + public abstract void deleteSync(List items); + + @Query("SELECT * FROM accounts WHERE profile_id=:profileId") + public abstract LiveData> getAll(long profileId); + + @Transaction + @Query("SELECT * FROM accounts WHERE profile_id = :profileId") + public abstract LiveData> getAllWithAmounts(long profileId); + + @Query("SELECT * FROM accounts WHERE id=:id") + public abstract Account getByIdSync(long id); // not useful for now // @Transaction @@ -60,6 +72,11 @@ public abstract class AccountDAO extends BaseDAO { @Query("SELECT * FROM accounts WHERE profile_id = :profileId AND name = :accountName") public abstract LiveData getByName(long profileId, @NonNull String accountName); + @Transaction + @Query("SELECT * FROM accounts WHERE profile_id = :profileId AND name = :accountName") + public abstract LiveData getByNameWithAmounts(long profileId, + @NonNull String accountName); + @Query("SELECT name, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + " WHEN name_upper LIKE '%%:'||:term||'%%' THEN 2 " + " WHEN name_upper LIKE '%% '||:term||'%%' THEN 3 " + @@ -93,6 +110,9 @@ public abstract class AccountDAO extends BaseDAO { "WHERE name_upper LIKE '%%'||:term||'%%' " + "ORDER BY ordering, name_upper, rowid ") public abstract List lookupByNameSync(@NonNull String term); + @Query("SELECT * FROM accounts WHERE profile_id = :profileId") + public abstract List allForProfileSync(long profileId); + static public class AccountNameContainer { @ColumnInfo public String name;