]> git.ktnx.net Git - mobile-ledger.git/blobdiff - app/src/main/java/net/ktnx/mobileledger/dao/TemplateHeaderDAO.java
rename Patterns to Templates
[mobile-ledger.git] / app / src / main / java / net / ktnx / mobileledger / dao / TemplateHeaderDAO.java
diff --git a/app/src/main/java/net/ktnx/mobileledger/dao/TemplateHeaderDAO.java b/app/src/main/java/net/ktnx/mobileledger/dao/TemplateHeaderDAO.java
new file mode 100644 (file)
index 0000000..faef98f
--- /dev/null
@@ -0,0 +1,53 @@
+/*
+ * Copyright © 2021 Damyan Ivanov.
+ * This file is part of MoLe.
+ * MoLe is free software: you can distribute it and/or modify it
+ * under the term of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your opinion), any later version.
+ *
+ * MoLe is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License terms for details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with MoLe. If not, see <https://www.gnu.org/licenses/>.
+ */
+
+package net.ktnx.mobileledger.dao;
+
+import androidx.lifecycle.LiveData;
+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.TemplateHeader;
+import net.ktnx.mobileledger.db.TemplateWithAccounts;
+
+import java.util.List;
+
+@Dao
+public interface TemplateHeaderDAO {
+    @Insert()
+    long insert(TemplateHeader item);
+
+    @Update
+    void update(TemplateHeader... items);
+
+    @Delete
+    void delete(TemplateHeader item);
+
+    @Query("SELECT * FROM templates ORDER BY UPPER(name)")
+    LiveData<List<TemplateHeader>> getTemplates();
+
+    @Query("SELECT * FROM templates WHERE id = :id")
+    LiveData<TemplateHeader> getTemplate(Long id);
+
+    @Transaction
+    @Query("SELECT * FROM templates WHERE id = :id")
+    LiveData<TemplateWithAccounts> getTemplateWithAccounts(Long id);
+}