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;fp=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fdao%2FAccountDAO.java;h=3bdf431d3189f52a17f69c3ae8ec0ad2b28912ed;hp=80bab0cc93dbfa0903cfa6f9a310a724fb55349c;hb=d6040b0ed8cc133b60ad25aa2f38e2cb9a6ad166;hpb=4c1949787f92e7e31687d3b3f8ce458478d3d966 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 80bab0cc..3bdf431d 100644 --- a/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java +++ b/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java @@ -23,6 +23,7 @@ import androidx.room.Dao; import androidx.room.Delete; import androidx.room.Insert; import androidx.room.Query; +import androidx.room.RoomWarnings; import androidx.room.Update; import net.ktnx.mobileledger.db.Account; @@ -51,4 +52,40 @@ public abstract class AccountDAO extends BaseDAO { // @Transaction // @Query("SELECT * FROM patterns") // List getPatternsWithAccounts(); + + @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + " WHEN name_upper LIKE '%%:'||:term||'%%' THEN 2 " + + " WHEN name_upper LIKE '%% '||:term||'%%' THEN 3 " + + " ELSE 9 END AS ordering " + "FROM accounts " + + "WHERE profile=:profileUUID AND name_upper LIKE '%%'||:term||'%%' " + + "ORDER BY ordering, name_upper, rowid ") + @SuppressWarnings(RoomWarnings.CURSOR_MISMATCH) + public abstract LiveData> lookupInProfileByName(@NonNull String profileUUID, + @NonNull String term); + + @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + " WHEN name_upper LIKE '%%:'||:term||'%%' THEN 2 " + + " WHEN name_upper LIKE '%% '||:term||'%%' THEN 3 " + + " ELSE 9 END AS ordering " + "FROM accounts " + + "WHERE profile=:profileUUID AND name_upper LIKE '%%'||:term||'%%' " + + "ORDER BY ordering, name_upper, rowid ") + @SuppressWarnings(RoomWarnings.CURSOR_MISMATCH) + public abstract List lookupInProfileByNameSync(@NonNull String profileUUID, + @NonNull String term); + + @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + " WHEN name_upper LIKE '%%:'||:term||'%%' THEN 2 " + + " WHEN name_upper LIKE '%% '||:term||'%%' THEN 3 " + + " ELSE 9 END AS ordering " + "FROM accounts " + + "WHERE name_upper LIKE '%%'||:term||'%%' " + "ORDER BY ordering, name_upper, rowid ") + @SuppressWarnings(RoomWarnings.CURSOR_MISMATCH) + public abstract LiveData> lookupByName(@NonNull String term); + + @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + " WHEN name_upper LIKE '%%:'||:term||'%%' THEN 2 " + + " WHEN name_upper LIKE '%% '||:term||'%%' THEN 3 " + + " ELSE 9 END AS ordering " + "FROM accounts " + + "WHERE name_upper LIKE '%%'||:term||'%%' " + "ORDER BY ordering, name_upper, rowid ") + @SuppressWarnings(RoomWarnings.CURSOR_MISMATCH) + public abstract List lookupByNameSync(@NonNull String term); }