]> git.ktnx.net Git - mobile-ledger.git/blob - dao/CurrencyDAO.java
bump androidx.constraintlayout library version
[mobile-ledger.git] / dao / CurrencyDAO.java
1 /*
2  * Copyright © 2021 Damyan Ivanov.
3  * This file is part of MoLe.
4  * MoLe is free software: you can distribute it and/or modify it
5  * under the term of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your opinion), any later version.
8  *
9  * MoLe is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License terms for details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with MoLe. If not, see <https://www.gnu.org/licenses/>.
16  */
17
18 package net.ktnx.mobileledger.dao;
19
20 import androidx.lifecycle.LiveData;
21 import androidx.room.Dao;
22 import androidx.room.Delete;
23 import androidx.room.Insert;
24 import androidx.room.OnConflictStrategy;
25 import androidx.room.Query;
26 import androidx.room.Update;
27
28 import net.ktnx.mobileledger.db.Currency;
29
30 import java.util.List;
31
32 @Dao
33 public abstract class CurrencyDAO extends BaseDAO<Currency> {
34     @Insert(onConflict = OnConflictStrategy.REPLACE)
35     abstract long insertSync(Currency item);
36
37     @Update
38     abstract void updateSync(Currency item);
39
40     @Delete
41     public abstract void deleteSync(Currency item);
42
43     @Query("SELECT * FROM currencies")
44     public abstract LiveData<List<Currency>> getAll();
45
46     @Query("SELECT * FROM currencies WHERE id = :id")
47     abstract LiveData<Currency> getById(long id);
48
49     @Query("SELECT * FROM currencies WHERE id = :id")
50     public abstract Currency getByIdSync(long id);
51
52     @Query("SELECT * FROM currencies WHERE name = :name")
53     public abstract LiveData<Currency> getByName(String name);
54
55 //    not useful for now
56 //    @Transaction
57 //    @Query("SELECT * FROM patterns")
58 //    List<PatternWithAccounts> getPatternsWithAccounts();
59 }