From 30b57df644a2f9c27f21b98ca2086eae1da9cfa5 Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期一, 07 四月 2025 15:04:21 +0800
Subject: [PATCH] add: 消息提醒前版本
---
app/src/main/java/com/example/firstapp/database/repository/CodeRepository.kt | 69 ++++++++++++++++++++++++++++++++++
1 files changed, 69 insertions(+), 0 deletions(-)
diff --git a/app/src/main/java/com/example/firstapp/database/repository/CodeRepository.kt b/app/src/main/java/com/example/firstapp/database/repository/CodeRepository.kt
index 2d9eceb..ad83877 100644
--- a/app/src/main/java/com/example/firstapp/database/repository/CodeRepository.kt
+++ b/app/src/main/java/com/example/firstapp/database/repository/CodeRepository.kt
@@ -3,6 +3,8 @@
import androidx.annotation.WorkerThread
import com.example.firstapp.database.dao.CodeDao
import com.example.firstapp.database.entity.Code
+import com.example.firstapp.model.StationGroup
+import kotlinx.coroutines.flow.Flow
class CodeRepository(private val codeDao: CodeDao) {
@@ -17,5 +19,72 @@
fun getAllDesc() = codeDao.getAllCodesDesc()
+ @WorkerThread
+ fun getByKeyword(keyword: String): List<Code> {
+ return codeDao.getByKeyword(keyword)
+ }
+
+ @WorkerThread
+ fun queryByTypeAndCodeAndDate(content: String, code: String, dateString: String): Code? {
+ return codeDao.queryByTypeAndCodeAndDate(content, code, dateString)
+ }
+
+ @WorkerThread
+ fun pickup(id: Long) = codeDao.pickup(id)
+
+
+ fun getPackages(date: Long, dateType: String): Flow<List<Code>> {
+ return when (dateType) {
+ "DAY" -> codeDao.getPackagesByDay(date)
+ "WEEK" -> codeDao.getPackagesByWeek(date)
+ else -> codeDao.getPackagesByDay(date)
+ }
+ }
+
+ fun getCourierStats(date: Long, dateType: String) = when(dateType) {
+ "WEEK" -> codeDao.getCourierStatsByWeek(date)
+ "MONTH" -> codeDao.getCourierStatsByMonth(date)
+ "YEAR" -> codeDao.getCourierStatsByYear(date)
+ else -> codeDao.getCourierStatsByWeek(date)
+ }
+
+// fun getStats(date: Long, dateType: String) = when(dateType) {
+// "WEEK" -> codeDao.getDailyStatsByWeek(date)
+// "MONTH" -> codeDao.getMonthlyStats(date)
+// "YEAR" -> codeDao.getYearlyStats(date)
+// else -> codeDao.getDailyStatsByWeek(date)
+// }
+
+
+ @WorkerThread
+ fun getPackagesByDay(date: Long): List<Code> {
+ return codeDao.getNewPackagesByDay(date)
+ }
+
+ fun getYearlyHeatmap(date: Long) = codeDao.getYearlyHeatmap(date)
+
+ fun getWeeklyStats(date: Long, weekCount: Int) = codeDao.getWeeklyStats(date, weekCount)
+
+ fun getMonthlyStats(date: Long) = codeDao.getMonthlyStats(date)
+
+
+ fun getYearlyStats(date: Long) = codeDao.getYearlyStats(date)
+
+ fun getYearMonthlyStats(date: Long) = codeDao.getYearMonthlyStats(date)
+
+
+ fun getCurrentWeekStats(date: Long) = codeDao.getCurrentWeekStats(date)
+
+ fun getCurrentYearStats(date: Long) = codeDao.getCurrentYearStats(date)
+
+ @WorkerThread
+ fun getStationsByType(type: String): List<StationGroup> {
+ return codeDao.getStationsByType(type)
+ }
+
+ @WorkerThread
+ fun getPackagesByTypeAndStation(type: String, stationName: String): List<Code> {
+ return codeDao.getPackagesByTypeAndStation(type, stationName)
+ }
}
\ No newline at end of file
--
Gitblit v1.9.3