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=31aafbf200fdf9dc6a796c55666ced9816e33ee5;hp=3bdf431d3189f52a17f69c3ae8ec0ad2b28912ed;hb=22abd84a5986a1b259b0e89d32669cbeb977a72b;hpb=97cc42840b31e0c8cfc67693e0b420c7c61ba6b5 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 3bdf431d..31aafbf2 100644 --- a/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java +++ b/app/src/main/java/net/ktnx/mobileledger/dao/AccountDAO.java @@ -19,15 +19,16 @@ package net.ktnx.mobileledger.dao; import androidx.annotation.NonNull; import androidx.lifecycle.LiveData; +import androidx.room.ColumnInfo; 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; +import java.util.ArrayList; import java.util.List; @Dao @@ -53,39 +54,50 @@ public abstract class AccountDAO extends BaseDAO { // @Query("SELECT * FROM patterns") // List getPatternsWithAccounts(); - @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + static public List unbox(List list) { + ArrayList result = new ArrayList<>(list.size()); + for (AccountNameContainer item : list) { + result.add(item.name); + } + + return result; + } + @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 " + " 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); + public abstract LiveData> lookupInProfileByName( + @NonNull String profileUUID, @NonNull String term); - @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + @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 " + " 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); + public abstract List lookupInProfileByNameSync( + @NonNull String profileUUID, @NonNull String term); - @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + @Query("SELECT DISTINCT name, 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); + public abstract LiveData> lookupByName(@NonNull String term); - @Query("SELECT *, CASE WHEN name_upper LIKE :term||'%%' THEN 1 " + + @Query("SELECT DISTINCT name, 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); + public abstract List lookupByNameSync(@NonNull String term); + + static public class AccountNameContainer { + @ColumnInfo + public String name; + @ColumnInfo + public int ordering; + } }