mirror of
https://github.com/wulkanowy/wulkanowy.git
synced 2025-01-20 02:16:44 -06:00
Merge branch 'release/1.4.4'
This commit is contained in:
commit
4e12eb1552
@ -22,8 +22,8 @@ android {
|
|||||||
testApplicationId "io.github.tests.wulkanowy"
|
testApplicationId "io.github.tests.wulkanowy"
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
targetSdkVersion 31
|
targetSdkVersion 31
|
||||||
versionCode 101
|
versionCode 102
|
||||||
versionName "1.4.3"
|
versionName "1.4.4"
|
||||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
||||||
|
|
||||||
resValue "string", "app_name", "Wulkanowy"
|
resValue "string", "app_name", "Wulkanowy"
|
||||||
@ -150,7 +150,7 @@ kapt {
|
|||||||
play {
|
play {
|
||||||
defaultToAppBundles = false
|
defaultToAppBundles = false
|
||||||
track = 'beta'
|
track = 'beta'
|
||||||
updatePriority = 1
|
updatePriority = 4
|
||||||
enabled.set(false)
|
enabled.set(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -174,7 +174,7 @@ ext {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation "io.github.wulkanowy:sdk:1.4.3"
|
implementation "io.github.wulkanowy:sdk:1.4.4"
|
||||||
|
|
||||||
coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:1.1.5'
|
coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:1.1.5'
|
||||||
|
|
||||||
@ -229,7 +229,7 @@ dependencies {
|
|||||||
implementation 'me.xdrop:fuzzywuzzy:1.3.1'
|
implementation 'me.xdrop:fuzzywuzzy:1.3.1'
|
||||||
implementation 'com.fredporciuncula:flow-preferences:1.6.0'
|
implementation 'com.fredporciuncula:flow-preferences:1.6.0'
|
||||||
|
|
||||||
playImplementation platform('com.google.firebase:firebase-bom:29.0.0')
|
playImplementation platform('com.google.firebase:firebase-bom:29.0.2')
|
||||||
playImplementation 'com.google.firebase:firebase-analytics-ktx'
|
playImplementation 'com.google.firebase:firebase-analytics-ktx'
|
||||||
playImplementation 'com.google.firebase:firebase-messaging:'
|
playImplementation 'com.google.firebase:firebase-messaging:'
|
||||||
playImplementation 'com.google.firebase:firebase-crashlytics:'
|
playImplementation 'com.google.firebase:firebase-crashlytics:'
|
||||||
@ -238,7 +238,7 @@ dependencies {
|
|||||||
playImplementation 'com.google.android.gms:play-services-ads:20.5.0'
|
playImplementation 'com.google.android.gms:play-services-ads:20.5.0'
|
||||||
|
|
||||||
hmsImplementation 'com.huawei.hms:hianalytics:6.3.2.300'
|
hmsImplementation 'com.huawei.hms:hianalytics:6.3.2.300'
|
||||||
hmsImplementation 'com.huawei.agconnect:agconnect-crash:1.6.2.200'
|
hmsImplementation 'com.huawei.agconnect:agconnect-crash:1.6.2.300'
|
||||||
|
|
||||||
releaseImplementation "com.github.ChuckerTeam.Chucker:library-no-op:$chucker"
|
releaseImplementation "com.github.ChuckerTeam.Chucker:library-no-op:$chucker"
|
||||||
|
|
||||||
@ -250,7 +250,7 @@ dependencies {
|
|||||||
testImplementation "org.jetbrains.kotlinx:kotlinx-coroutines-test:$coroutines"
|
testImplementation "org.jetbrains.kotlinx:kotlinx-coroutines-test:$coroutines"
|
||||||
testImplementation "org.jetbrains.kotlin:kotlin-test:$kotlin_version"
|
testImplementation "org.jetbrains.kotlin:kotlin-test:$kotlin_version"
|
||||||
|
|
||||||
testImplementation 'org.robolectric:robolectric:4.7.2'
|
testImplementation 'org.robolectric:robolectric:4.7.3'
|
||||||
testImplementation "androidx.test:runner:1.4.0"
|
testImplementation "androidx.test:runner:1.4.0"
|
||||||
testImplementation "androidx.test.ext:junit:1.1.3"
|
testImplementation "androidx.test.ext:junit:1.1.3"
|
||||||
testImplementation "androidx.test:core:1.4.0"
|
testImplementation "androidx.test:core:1.4.0"
|
||||||
|
@ -6,6 +6,7 @@ import io.github.wulkanowy.ui.modules.main.MainActivity
|
|||||||
import javax.inject.Singleton
|
import javax.inject.Singleton
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
|
@Suppress("UNUSED_PARAMETER", "unused")
|
||||||
@Singleton
|
@Singleton
|
||||||
class InAppReviewHelper @Inject constructor(
|
class InAppReviewHelper @Inject constructor(
|
||||||
@ApplicationContext private val context: Context
|
@ApplicationContext private val context: Context
|
||||||
|
@ -10,6 +10,6 @@ import javax.inject.Singleton
|
|||||||
@Singleton
|
@Singleton
|
||||||
interface SchoolAnnouncementDao : BaseDao<SchoolAnnouncement> {
|
interface SchoolAnnouncementDao : BaseDao<SchoolAnnouncement> {
|
||||||
|
|
||||||
@Query("SELECT * FROM SchoolAnnouncements WHERE student_id = :studentId")
|
@Query("SELECT * FROM SchoolAnnouncements WHERE student_id = :studentId ORDER BY date DESC")
|
||||||
fun loadAll(studentId: Int): Flow<List<SchoolAnnouncement>>
|
fun loadAll(studentId: Int): Flow<List<SchoolAnnouncement>>
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@ package io.github.wulkanowy.data.db.migrations
|
|||||||
import androidx.room.migration.Migration
|
import androidx.room.migration.Migration
|
||||||
import androidx.sqlite.db.SupportSQLiteDatabase
|
import androidx.sqlite.db.SupportSQLiteDatabase
|
||||||
import io.github.wulkanowy.data.db.SharedPrefProvider
|
import io.github.wulkanowy.data.db.SharedPrefProvider
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeExpandMode
|
import io.github.wulkanowy.data.enums.GradeExpandMode
|
||||||
|
|
||||||
class Migration41(private val sharedPrefProvider: SharedPrefProvider) : Migration(40, 41) {
|
class Migration41(private val sharedPrefProvider: SharedPrefProvider) : Migration(40, 41) {
|
||||||
|
|
||||||
|
12
app/src/main/java/io/github/wulkanowy/data/enums/AppTheme.kt
Normal file
12
app/src/main/java/io/github/wulkanowy/data/enums/AppTheme.kt
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
package io.github.wulkanowy.data.enums
|
||||||
|
|
||||||
|
enum class AppTheme(val value: String) {
|
||||||
|
SYSTEM("system"),
|
||||||
|
LIGHT("light"),
|
||||||
|
DARK("dark"),
|
||||||
|
BLACK("black");
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
fun getByValue(value: String) = values().find { it.value == value } ?: LIGHT
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,13 @@
|
|||||||
|
package io.github.wulkanowy.data.enums
|
||||||
|
|
||||||
|
import java.io.Serializable
|
||||||
|
|
||||||
|
enum class GradeColorTheme(val value: String) : Serializable {
|
||||||
|
VULCAN("vulcan"),
|
||||||
|
MATERIAL("material"),
|
||||||
|
GRADE_COLOR("grade_color");
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
fun getByValue(value: String) = values().find { it.value == value } ?: VULCAN
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,11 @@
|
|||||||
|
package io.github.wulkanowy.data.enums
|
||||||
|
|
||||||
|
enum class GradeExpandMode(val value: String) {
|
||||||
|
ONE("one"),
|
||||||
|
UNLIMITED("any"),
|
||||||
|
ALWAYS_EXPANDED("always");
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
fun getByValue(value: String) = values().find { it.value == value } ?: ONE
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
package io.github.wulkanowy.data.enums
|
||||||
|
|
||||||
|
enum class GradeSortingMode(val value: String) {
|
||||||
|
ALPHABETIC("alphabetic"),
|
||||||
|
DATE("date");
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
fun getByValue(value: String) = values().find { it.value == value } ?: ALPHABETIC
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,11 @@
|
|||||||
|
package io.github.wulkanowy.data.enums
|
||||||
|
|
||||||
|
enum class TimetableMode(val value: String) {
|
||||||
|
WHOLE_PLAN("yes"),
|
||||||
|
ONLY_CURRENT_GROUP("no"),
|
||||||
|
SMALL_OTHER_GROUP("small");
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
fun getByValue(value: String) = values().find { it.value == value } ?: ONLY_CURRENT_GROUP
|
||||||
|
}
|
||||||
|
}
|
@ -7,11 +7,14 @@ import com.fredporciuncula.flow.preferences.FlowSharedPreferences
|
|||||||
import com.fredporciuncula.flow.preferences.Preference
|
import com.fredporciuncula.flow.preferences.Preference
|
||||||
import dagger.hilt.android.qualifiers.ApplicationContext
|
import dagger.hilt.android.qualifiers.ApplicationContext
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
|
import io.github.wulkanowy.data.enums.AppTheme
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
|
import io.github.wulkanowy.data.enums.GradeExpandMode
|
||||||
|
import io.github.wulkanowy.data.enums.GradeSortingMode
|
||||||
|
import io.github.wulkanowy.data.enums.TimetableMode
|
||||||
import io.github.wulkanowy.sdk.toLocalDate
|
import io.github.wulkanowy.sdk.toLocalDate
|
||||||
import io.github.wulkanowy.ui.modules.dashboard.DashboardItem
|
import io.github.wulkanowy.ui.modules.dashboard.DashboardItem
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeAverageMode
|
import io.github.wulkanowy.ui.modules.grade.GradeAverageMode
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeExpandMode
|
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeSortingMode
|
|
||||||
import io.github.wulkanowy.utils.toLocalDateTime
|
import io.github.wulkanowy.utils.toLocalDateTime
|
||||||
import io.github.wulkanowy.utils.toTimestamp
|
import io.github.wulkanowy.utils.toTimestamp
|
||||||
import kotlinx.coroutines.ExperimentalCoroutinesApi
|
import kotlinx.coroutines.ExperimentalCoroutinesApi
|
||||||
@ -72,13 +75,15 @@ class PreferencesRepository @Inject constructor(
|
|||||||
)
|
)
|
||||||
|
|
||||||
val appThemeKey = context.getString(R.string.pref_key_app_theme)
|
val appThemeKey = context.getString(R.string.pref_key_app_theme)
|
||||||
val appTheme: String
|
val appTheme: AppTheme
|
||||||
get() = getString(appThemeKey, R.string.pref_default_app_theme)
|
get() = AppTheme.getByValue(getString(appThemeKey, R.string.pref_default_app_theme))
|
||||||
|
|
||||||
val gradeColorTheme: String
|
val gradeColorTheme: GradeColorTheme
|
||||||
get() = getString(
|
get() = GradeColorTheme.getByValue(
|
||||||
R.string.pref_key_grade_color_scheme,
|
getString(
|
||||||
R.string.pref_default_grade_color_scheme
|
R.string.pref_key_grade_color_scheme,
|
||||||
|
R.string.pref_default_grade_color_scheme
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
val appLanguageKey = context.getString(R.string.pref_key_app_language)
|
val appLanguageKey = context.getString(R.string.pref_key_app_language)
|
||||||
@ -156,10 +161,12 @@ class PreferencesRepository @Inject constructor(
|
|||||||
R.bool.pref_default_timetable_show_groups
|
R.bool.pref_default_timetable_show_groups
|
||||||
)
|
)
|
||||||
|
|
||||||
val showWholeClassPlan: String
|
val showWholeClassPlan: TimetableMode
|
||||||
get() = getString(
|
get() = TimetableMode.getByValue(
|
||||||
R.string.pref_key_timetable_show_whole_class,
|
getString(
|
||||||
R.string.pref_default_timetable_show_whole_class
|
R.string.pref_key_timetable_show_whole_class,
|
||||||
|
R.string.pref_default_timetable_show_whole_class
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
val gradeSortingMode: GradeSortingMode
|
val gradeSortingMode: GradeSortingMode
|
||||||
|
@ -74,7 +74,7 @@ class AppNotificationManager @Inject constructor(
|
|||||||
student: Student
|
student: Student
|
||||||
) {
|
) {
|
||||||
val notificationType = groupNotificationData.type
|
val notificationType = groupNotificationData.type
|
||||||
val groupType = notificationType.group ?: return
|
val groupType = notificationType.channel
|
||||||
val group = "${groupType}_${student.id}"
|
val group = "${groupType}_${student.id}"
|
||||||
|
|
||||||
sendSummaryNotification(groupNotificationData, group, student)
|
sendSummaryNotification(groupNotificationData, group, student)
|
||||||
|
@ -14,72 +14,58 @@ import io.github.wulkanowy.services.sync.channels.PushChannel
|
|||||||
import io.github.wulkanowy.services.sync.channels.TimetableChangeChannel
|
import io.github.wulkanowy.services.sync.channels.TimetableChangeChannel
|
||||||
|
|
||||||
enum class NotificationType(
|
enum class NotificationType(
|
||||||
val group: String?,
|
|
||||||
val channel: String,
|
val channel: String,
|
||||||
val icon: Int
|
val icon: Int
|
||||||
) {
|
) {
|
||||||
NEW_CONFERENCE(
|
NEW_CONFERENCE(
|
||||||
group = "new_conferences_group",
|
|
||||||
channel = NewConferencesChannel.CHANNEL_ID,
|
channel = NewConferencesChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_more_conferences,
|
icon = R.drawable.ic_more_conferences,
|
||||||
),
|
),
|
||||||
NEW_EXAM(
|
NEW_EXAM(
|
||||||
group = "new_exam_group",
|
|
||||||
channel = NewExamChannel.CHANNEL_ID,
|
channel = NewExamChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_main_exam
|
icon = R.drawable.ic_main_exam
|
||||||
),
|
),
|
||||||
NEW_GRADE_DETAILS(
|
NEW_GRADE_DETAILS(
|
||||||
group = "new_grade_details_group",
|
|
||||||
channel = NewGradesChannel.CHANNEL_ID,
|
channel = NewGradesChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_grade,
|
icon = R.drawable.ic_stat_grade,
|
||||||
),
|
),
|
||||||
NEW_GRADE_PREDICTED(
|
NEW_GRADE_PREDICTED(
|
||||||
group = "new_grade_predicted_group",
|
|
||||||
channel = NewGradesChannel.CHANNEL_ID,
|
channel = NewGradesChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_grade,
|
icon = R.drawable.ic_stat_grade,
|
||||||
),
|
),
|
||||||
NEW_GRADE_FINAL(
|
NEW_GRADE_FINAL(
|
||||||
group = "new_grade_final_group",
|
|
||||||
channel = NewGradesChannel.CHANNEL_ID,
|
channel = NewGradesChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_grade,
|
icon = R.drawable.ic_stat_grade,
|
||||||
),
|
),
|
||||||
NEW_HOMEWORK(
|
NEW_HOMEWORK(
|
||||||
group = "new_homework_group",
|
|
||||||
channel = NewHomeworkChannel.CHANNEL_ID,
|
channel = NewHomeworkChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_more_homework,
|
icon = R.drawable.ic_more_homework,
|
||||||
),
|
),
|
||||||
NEW_LUCKY_NUMBER(
|
NEW_LUCKY_NUMBER(
|
||||||
group = null,
|
|
||||||
channel = LuckyNumberChannel.CHANNEL_ID,
|
channel = LuckyNumberChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_luckynumber,
|
icon = R.drawable.ic_stat_luckynumber,
|
||||||
),
|
),
|
||||||
NEW_MESSAGE(
|
NEW_MESSAGE(
|
||||||
group = "new_message_group",
|
|
||||||
channel = NewMessagesChannel.CHANNEL_ID,
|
channel = NewMessagesChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_message,
|
icon = R.drawable.ic_stat_message,
|
||||||
),
|
),
|
||||||
NEW_NOTE(
|
NEW_NOTE(
|
||||||
group = "new_notes_group",
|
|
||||||
channel = NewNotesChannel.CHANNEL_ID,
|
channel = NewNotesChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_note
|
icon = R.drawable.ic_stat_note
|
||||||
),
|
),
|
||||||
NEW_ANNOUNCEMENT(
|
NEW_ANNOUNCEMENT(
|
||||||
group = "new_school_announcements_group",
|
|
||||||
channel = NewSchoolAnnouncementsChannel.CHANNEL_ID,
|
channel = NewSchoolAnnouncementsChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_all_about
|
icon = R.drawable.ic_all_about
|
||||||
),
|
),
|
||||||
CHANGE_TIMETABLE(
|
CHANGE_TIMETABLE(
|
||||||
group = "change_timetable_group",
|
|
||||||
channel = TimetableChangeChannel.CHANNEL_ID,
|
channel = TimetableChangeChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_main_timetable
|
icon = R.drawable.ic_main_timetable
|
||||||
),
|
),
|
||||||
NEW_ATTENDANCE(
|
NEW_ATTENDANCE(
|
||||||
group = "new_attendance_group",
|
|
||||||
channel = NewAttendanceChannel.CHANNEL_ID,
|
channel = NewAttendanceChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_main_attendance
|
icon = R.drawable.ic_main_attendance
|
||||||
),
|
),
|
||||||
PUSH(
|
PUSH(
|
||||||
group = null,
|
|
||||||
channel = PushChannel.CHANNEL_ID,
|
channel = PushChannel.CHANNEL_ID,
|
||||||
icon = R.drawable.ic_stat_all
|
icon = R.drawable.ic_stat_all
|
||||||
)
|
)
|
||||||
|
@ -7,6 +7,7 @@ import androidx.appcompat.app.AppCompatDelegate.MODE_NIGHT_FOLLOW_SYSTEM
|
|||||||
import androidx.appcompat.app.AppCompatDelegate.MODE_NIGHT_NO
|
import androidx.appcompat.app.AppCompatDelegate.MODE_NIGHT_NO
|
||||||
import androidx.appcompat.app.AppCompatDelegate.MODE_NIGHT_YES
|
import androidx.appcompat.app.AppCompatDelegate.MODE_NIGHT_YES
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
|
import io.github.wulkanowy.data.enums.AppTheme
|
||||||
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
||||||
import io.github.wulkanowy.ui.modules.login.LoginActivity
|
import io.github.wulkanowy.ui.modules.login.LoginActivity
|
||||||
import io.github.wulkanowy.ui.modules.main.MainActivity
|
import io.github.wulkanowy.ui.modules.main.MainActivity
|
||||||
@ -20,7 +21,7 @@ class ThemeManager @Inject constructor(private val preferencesRepository: Prefer
|
|||||||
fun applyActivityTheme(activity: AppCompatActivity) {
|
fun applyActivityTheme(activity: AppCompatActivity) {
|
||||||
if (isThemeApplicable(activity)) {
|
if (isThemeApplicable(activity)) {
|
||||||
applyDefaultTheme()
|
applyDefaultTheme()
|
||||||
if (preferencesRepository.appTheme == "black") {
|
if (preferencesRepository.appTheme == AppTheme.BLACK) {
|
||||||
when (activity) {
|
when (activity) {
|
||||||
is MainActivity -> activity.setTheme(R.style.WulkanowyTheme_Black)
|
is MainActivity -> activity.setTheme(R.style.WulkanowyTheme_Black)
|
||||||
is LoginActivity -> activity.setTheme(R.style.WulkanowyTheme_Login_Black)
|
is LoginActivity -> activity.setTheme(R.style.WulkanowyTheme_Login_Black)
|
||||||
@ -32,11 +33,10 @@ class ThemeManager @Inject constructor(private val preferencesRepository: Prefer
|
|||||||
|
|
||||||
fun applyDefaultTheme() {
|
fun applyDefaultTheme() {
|
||||||
AppCompatDelegate.setDefaultNightMode(
|
AppCompatDelegate.setDefaultNightMode(
|
||||||
when (val theme = preferencesRepository.appTheme) {
|
when (preferencesRepository.appTheme) {
|
||||||
"light" -> MODE_NIGHT_NO
|
AppTheme.LIGHT -> MODE_NIGHT_NO
|
||||||
"dark", "black" -> MODE_NIGHT_YES
|
AppTheme.DARK, AppTheme.BLACK -> MODE_NIGHT_YES
|
||||||
"system" -> MODE_NIGHT_FOLLOW_SYSTEM
|
AppTheme.SYSTEM -> MODE_NIGHT_FOLLOW_SYSTEM
|
||||||
else -> throw IllegalArgumentException("Wrong theme: $theme")
|
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@ import io.github.wulkanowy.data.db.entities.AdminMessage
|
|||||||
import io.github.wulkanowy.data.db.entities.Student
|
import io.github.wulkanowy.data.db.entities.Student
|
||||||
import io.github.wulkanowy.data.db.entities.Timetable
|
import io.github.wulkanowy.data.db.entities.Timetable
|
||||||
import io.github.wulkanowy.data.db.entities.TimetableHeader
|
import io.github.wulkanowy.data.db.entities.TimetableHeader
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.databinding.ItemDashboardAccountBinding
|
import io.github.wulkanowy.databinding.ItemDashboardAccountBinding
|
||||||
import io.github.wulkanowy.databinding.ItemDashboardAdminMessageBinding
|
import io.github.wulkanowy.databinding.ItemDashboardAdminMessageBinding
|
||||||
import io.github.wulkanowy.databinding.ItemDashboardAnnouncementsBinding
|
import io.github.wulkanowy.databinding.ItemDashboardAnnouncementsBinding
|
||||||
@ -262,7 +263,7 @@ class DashboardAdapter @Inject constructor() : RecyclerView.Adapter<RecyclerView
|
|||||||
val isLoading = item.isLoading
|
val isLoading = item.isLoading
|
||||||
val dashboardGradesAdapter = gradesViewHolder.adapter.apply {
|
val dashboardGradesAdapter = gradesViewHolder.adapter.apply {
|
||||||
this.items = subjectWithGrades.toList()
|
this.items = subjectWithGrades.toList()
|
||||||
this.gradeTheme = gradeTheme.orEmpty()
|
this.gradeColorTheme = gradeTheme ?: GradeColorTheme.VULCAN
|
||||||
}
|
}
|
||||||
|
|
||||||
with(gradesViewHolder.binding) {
|
with(gradesViewHolder.binding) {
|
||||||
@ -421,10 +422,12 @@ class DashboardAdapter @Inject constructor() : RecyclerView.Adapter<RecyclerView
|
|||||||
isFirstTimeRangeVisible = true
|
isFirstTimeRangeVisible = true
|
||||||
isFirstTimeVisible = false
|
isFirstTimeVisible = false
|
||||||
} else {
|
} else {
|
||||||
firstTimeText = context.resources.getQuantityString(
|
firstTimeText = context.getString(
|
||||||
R.plurals.dashboard_timetable_first_lesson_time_in_minutes,
|
R.string.timetable_time_until,
|
||||||
minutesToStartLesson.toInt(),
|
context.getString(
|
||||||
minutesToStartLesson
|
R.string.timetable_minutes,
|
||||||
|
minutesToStartLesson.toString()
|
||||||
|
)
|
||||||
)
|
)
|
||||||
firstTimeRangeText = ""
|
firstTimeRangeText = ""
|
||||||
|
|
||||||
@ -460,10 +463,12 @@ class DashboardAdapter @Inject constructor() : RecyclerView.Adapter<RecyclerView
|
|||||||
0
|
0
|
||||||
}
|
}
|
||||||
|
|
||||||
firstTimeText = context.resources.getQuantityString(
|
firstTimeText = context.getString(
|
||||||
R.plurals.dashboard_timetable_first_lesson_time_more_minutes,
|
R.string.timetable_time_left,
|
||||||
minutesToEndLesson.toInt(),
|
context.getString(
|
||||||
minutesToEndLesson
|
R.string.timetable_minutes,
|
||||||
|
minutesToEndLesson.toString()
|
||||||
|
)
|
||||||
)
|
)
|
||||||
firstTimeRangeText = ""
|
firstTimeRangeText = ""
|
||||||
|
|
||||||
|
@ -4,6 +4,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.recyclerview.widget.RecyclerView
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.databinding.SubitemDashboardGradesBinding
|
import io.github.wulkanowy.databinding.SubitemDashboardGradesBinding
|
||||||
import io.github.wulkanowy.databinding.SubitemDashboardSmallGradeBinding
|
import io.github.wulkanowy.databinding.SubitemDashboardSmallGradeBinding
|
||||||
import io.github.wulkanowy.utils.getBackgroundColor
|
import io.github.wulkanowy.utils.getBackgroundColor
|
||||||
@ -12,7 +13,7 @@ class DashboardGradesAdapter : RecyclerView.Adapter<DashboardGradesAdapter.ViewH
|
|||||||
|
|
||||||
var items = listOf<Pair<String, List<Grade>>>()
|
var items = listOf<Pair<String, List<Grade>>>()
|
||||||
|
|
||||||
var gradeTheme = ""
|
lateinit var gradeColorTheme: GradeColorTheme
|
||||||
|
|
||||||
override fun getItemCount() = items.size
|
override fun getItemCount() = items.size
|
||||||
|
|
||||||
@ -36,7 +37,7 @@ class DashboardGradesAdapter : RecyclerView.Adapter<DashboardGradesAdapter.ViewH
|
|||||||
|
|
||||||
with(subitemBinding.dashboardSmallGradeSubitemValue) {
|
with(subitemBinding.dashboardSmallGradeSubitemValue) {
|
||||||
text = it.entry
|
text = it.entry
|
||||||
setBackgroundResource(it.getBackgroundColor(gradeTheme))
|
setBackgroundResource(it.getBackgroundColor(gradeColorTheme))
|
||||||
}
|
}
|
||||||
|
|
||||||
dashboardGradesSubitemGradeContainer.addView(subitemBinding.root)
|
dashboardGradesSubitemGradeContainer.addView(subitemBinding.root)
|
||||||
|
@ -6,6 +6,7 @@ import io.github.wulkanowy.data.db.entities.Exam
|
|||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
import io.github.wulkanowy.data.db.entities.SchoolAnnouncement
|
import io.github.wulkanowy.data.db.entities.SchoolAnnouncement
|
||||||
import io.github.wulkanowy.data.db.entities.Student
|
import io.github.wulkanowy.data.db.entities.Student
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.data.pojos.TimetableFull
|
import io.github.wulkanowy.data.pojos.TimetableFull
|
||||||
import io.github.wulkanowy.data.db.entities.Homework as EntitiesHomework
|
import io.github.wulkanowy.data.db.entities.Homework as EntitiesHomework
|
||||||
|
|
||||||
@ -52,7 +53,7 @@ sealed class DashboardItem(val type: Type) {
|
|||||||
|
|
||||||
data class Grades(
|
data class Grades(
|
||||||
val subjectWithGrades: Map<String, List<Grade>>? = null,
|
val subjectWithGrades: Map<String, List<Grade>>? = null,
|
||||||
val gradeTheme: String? = null,
|
val gradeTheme: GradeColorTheme? = null,
|
||||||
override val error: Throwable? = null,
|
override val error: Throwable? = null,
|
||||||
override val isLoading: Boolean = false
|
override val isLoading: Boolean = false
|
||||||
) : DashboardItem(Type.GRADES) {
|
) : DashboardItem(Type.GRADES) {
|
||||||
|
@ -1,9 +0,0 @@
|
|||||||
package io.github.wulkanowy.ui.modules.grade
|
|
||||||
|
|
||||||
enum class GradeExpandMode(val value: String) {
|
|
||||||
ONE("one"), UNLIMITED("any"), ALWAYS_EXPANDED("always");
|
|
||||||
|
|
||||||
companion object {
|
|
||||||
fun getByValue(value: String) = values().firstOrNull { it.value == value } ?: ONE
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
package io.github.wulkanowy.ui.modules.grade
|
|
||||||
|
|
||||||
enum class GradeSortingMode(val value: String) {
|
|
||||||
ALPHABETIC("alphabetic"),
|
|
||||||
DATE("date");
|
|
||||||
|
|
||||||
companion object {
|
|
||||||
fun getByValue(value: String) = values().firstOrNull { it.value == value } ?: ALPHABETIC
|
|
||||||
}
|
|
||||||
}
|
|
@ -11,10 +11,11 @@ import androidx.recyclerview.widget.RecyclerView
|
|||||||
import androidx.recyclerview.widget.RecyclerView.NO_POSITION
|
import androidx.recyclerview.widget.RecyclerView.NO_POSITION
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
|
import io.github.wulkanowy.data.enums.GradeExpandMode
|
||||||
import io.github.wulkanowy.databinding.HeaderGradeDetailsBinding
|
import io.github.wulkanowy.databinding.HeaderGradeDetailsBinding
|
||||||
import io.github.wulkanowy.databinding.ItemGradeDetailsBinding
|
import io.github.wulkanowy.databinding.ItemGradeDetailsBinding
|
||||||
import io.github.wulkanowy.ui.base.BaseExpandableAdapter
|
import io.github.wulkanowy.ui.base.BaseExpandableAdapter
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeExpandMode
|
|
||||||
import io.github.wulkanowy.utils.getBackgroundColor
|
import io.github.wulkanowy.utils.getBackgroundColor
|
||||||
import io.github.wulkanowy.utils.toFormattedString
|
import io.github.wulkanowy.utils.toFormattedString
|
||||||
import timber.log.Timber
|
import timber.log.Timber
|
||||||
@ -33,7 +34,7 @@ class GradeDetailsAdapter @Inject constructor() : BaseExpandableAdapter<Recycler
|
|||||||
|
|
||||||
var onClickListener: (Grade, position: Int) -> Unit = { _, _ -> }
|
var onClickListener: (Grade, position: Int) -> Unit = { _, _ -> }
|
||||||
|
|
||||||
var colorTheme = ""
|
lateinit var gradeColorTheme: GradeColorTheme
|
||||||
|
|
||||||
fun setDataItems(data: List<GradeDetailsItem>, expandMode: GradeExpandMode = this.expandMode) {
|
fun setDataItems(data: List<GradeDetailsItem>, expandMode: GradeExpandMode = this.expandMode) {
|
||||||
headers = data.filter { it.viewType == ViewType.HEADER }.toMutableList()
|
headers = data.filter { it.viewType == ViewType.HEADER }.toMutableList()
|
||||||
@ -202,7 +203,7 @@ class GradeDetailsAdapter @Inject constructor() : BaseExpandableAdapter<Recycler
|
|||||||
with(holder.binding) {
|
with(holder.binding) {
|
||||||
gradeItemValue.run {
|
gradeItemValue.run {
|
||||||
text = grade.entry
|
text = grade.entry
|
||||||
setBackgroundResource(grade.getBackgroundColor(colorTheme))
|
setBackgroundResource(grade.getBackgroundColor(gradeColorTheme))
|
||||||
}
|
}
|
||||||
gradeItemDescription.text = when {
|
gradeItemDescription.text = when {
|
||||||
grade.description.isNotBlank() -> grade.description
|
grade.description.isNotBlank() -> grade.description
|
||||||
|
@ -8,6 +8,7 @@ import android.view.ViewGroup
|
|||||||
import androidx.fragment.app.DialogFragment
|
import androidx.fragment.app.DialogFragment
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.databinding.DialogGradeBinding
|
import io.github.wulkanowy.databinding.DialogGradeBinding
|
||||||
import io.github.wulkanowy.utils.colorStringId
|
import io.github.wulkanowy.utils.colorStringId
|
||||||
import io.github.wulkanowy.utils.getBackgroundColor
|
import io.github.wulkanowy.utils.getBackgroundColor
|
||||||
@ -21,19 +22,19 @@ class GradeDetailsDialog : DialogFragment() {
|
|||||||
|
|
||||||
private lateinit var grade: Grade
|
private lateinit var grade: Grade
|
||||||
|
|
||||||
private lateinit var colorScheme: String
|
private lateinit var gradeColorTheme: GradeColorTheme
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
private const val ARGUMENT_KEY = "Item"
|
private const val ARGUMENT_KEY = "Item"
|
||||||
|
|
||||||
private const val COLOR_SCHEME_KEY = "Scheme"
|
private const val COLOR_THEME_KEY = "Theme"
|
||||||
|
|
||||||
fun newInstance(grade: Grade, colorScheme: String) =
|
fun newInstance(grade: Grade, colorTheme: GradeColorTheme) =
|
||||||
GradeDetailsDialog().apply {
|
GradeDetailsDialog().apply {
|
||||||
arguments = Bundle().apply {
|
arguments = Bundle().apply {
|
||||||
putSerializable(ARGUMENT_KEY, grade)
|
putSerializable(ARGUMENT_KEY, grade)
|
||||||
putString(COLOR_SCHEME_KEY, colorScheme)
|
putSerializable(COLOR_THEME_KEY, colorTheme)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -43,7 +44,7 @@ class GradeDetailsDialog : DialogFragment() {
|
|||||||
setStyle(STYLE_NO_TITLE, 0)
|
setStyle(STYLE_NO_TITLE, 0)
|
||||||
arguments?.run {
|
arguments?.run {
|
||||||
grade = getSerializable(ARGUMENT_KEY) as Grade
|
grade = getSerializable(ARGUMENT_KEY) as Grade
|
||||||
colorScheme = getString(COLOR_SCHEME_KEY) ?: "default"
|
gradeColorTheme = getSerializable(COLOR_THEME_KEY) as GradeColorTheme
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,7 +77,7 @@ class GradeDetailsDialog : DialogFragment() {
|
|||||||
|
|
||||||
gradeDialogValue.run {
|
gradeDialogValue.run {
|
||||||
text = grade.entry
|
text = grade.entry
|
||||||
setBackgroundResource(grade.getBackgroundColor(colorScheme))
|
setBackgroundResource(grade.getBackgroundColor(gradeColorTheme))
|
||||||
}
|
}
|
||||||
|
|
||||||
gradeDialogTeacherValue.text = if (grade.teacher.isBlank()) {
|
gradeDialogTeacherValue.text = if (grade.teacher.isBlank()) {
|
||||||
|
@ -12,7 +12,8 @@ import androidx.recyclerview.widget.LinearLayoutManager
|
|||||||
import dagger.hilt.android.AndroidEntryPoint
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeExpandMode
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
|
import io.github.wulkanowy.data.enums.GradeExpandMode
|
||||||
import io.github.wulkanowy.databinding.FragmentGradeDetailsBinding
|
import io.github.wulkanowy.databinding.FragmentGradeDetailsBinding
|
||||||
import io.github.wulkanowy.ui.base.BaseFragment
|
import io.github.wulkanowy.ui.base.BaseFragment
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeFragment
|
import io.github.wulkanowy.ui.modules.grade.GradeFragment
|
||||||
@ -80,9 +81,9 @@ class GradeDetailsFragment :
|
|||||||
else false
|
else false
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun updateData(data: List<GradeDetailsItem>, expandMode: GradeExpandMode, gradeColorTheme: String) {
|
override fun updateData(data: List<GradeDetailsItem>, expandMode: GradeExpandMode, gradeColorTheme: GradeColorTheme) {
|
||||||
with(gradeDetailsAdapter) {
|
with(gradeDetailsAdapter) {
|
||||||
colorTheme = gradeColorTheme
|
this.gradeColorTheme = gradeColorTheme
|
||||||
setDataItems(data, expandMode)
|
setDataItems(data, expandMode)
|
||||||
notifyDataSetChanged()
|
notifyDataSetChanged()
|
||||||
}
|
}
|
||||||
@ -143,8 +144,8 @@ class GradeDetailsFragment :
|
|||||||
binding.gradeDetailsSwipe.isRefreshing = show
|
binding.gradeDetailsSwipe.isRefreshing = show
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun showGradeDialog(grade: Grade, colorScheme: String) {
|
override fun showGradeDialog(grade: Grade, colorTheme: GradeColorTheme) {
|
||||||
(activity as? MainActivity)?.showDialogFragment(GradeDetailsDialog.newInstance(grade, colorScheme))
|
(activity as? MainActivity)?.showDialogFragment(GradeDetailsDialog.newInstance(grade, colorTheme))
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onParentLoadData(semesterId: Int, forceRefresh: Boolean) {
|
override fun onParentLoadData(semesterId: Int, forceRefresh: Boolean) {
|
||||||
|
@ -2,6 +2,9 @@ package io.github.wulkanowy.ui.modules.grade.details
|
|||||||
|
|
||||||
import io.github.wulkanowy.data.Status
|
import io.github.wulkanowy.data.Status
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
|
import io.github.wulkanowy.data.enums.GradeExpandMode
|
||||||
|
import io.github.wulkanowy.data.enums.GradeSortingMode.ALPHABETIC
|
||||||
|
import io.github.wulkanowy.data.enums.GradeSortingMode.DATE
|
||||||
import io.github.wulkanowy.data.repositories.GradeRepository
|
import io.github.wulkanowy.data.repositories.GradeRepository
|
||||||
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
||||||
import io.github.wulkanowy.data.repositories.SemesterRepository
|
import io.github.wulkanowy.data.repositories.SemesterRepository
|
||||||
@ -9,9 +12,6 @@ import io.github.wulkanowy.data.repositories.StudentRepository
|
|||||||
import io.github.wulkanowy.ui.base.BasePresenter
|
import io.github.wulkanowy.ui.base.BasePresenter
|
||||||
import io.github.wulkanowy.ui.base.ErrorHandler
|
import io.github.wulkanowy.ui.base.ErrorHandler
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeAverageProvider
|
import io.github.wulkanowy.ui.modules.grade.GradeAverageProvider
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeExpandMode
|
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeSortingMode.ALPHABETIC
|
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeSortingMode.DATE
|
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeSubject
|
import io.github.wulkanowy.ui.modules.grade.GradeSubject
|
||||||
import io.github.wulkanowy.utils.AnalyticsHelper
|
import io.github.wulkanowy.utils.AnalyticsHelper
|
||||||
import io.github.wulkanowy.utils.afterLoading
|
import io.github.wulkanowy.utils.afterLoading
|
||||||
@ -230,10 +230,14 @@ class GradeDetailsPresenter @Inject constructor(
|
|||||||
gradesWithAverages.filter { it.grades.isNotEmpty() }
|
gradesWithAverages.filter { it.grades.isNotEmpty() }
|
||||||
} else gradesWithAverages
|
} else gradesWithAverages
|
||||||
}
|
}
|
||||||
.let {
|
.let { gradeSubjects ->
|
||||||
when (preferencesRepository.gradeSortingMode) {
|
when (preferencesRepository.gradeSortingMode) {
|
||||||
DATE -> it.sortedByDescending { gradeDetailsWithAverage -> gradeDetailsWithAverage.grades.firstOrNull()?.date }
|
DATE -> gradeSubjects.sortedByDescending { gradeDetailsWithAverage ->
|
||||||
ALPHABETIC -> it.sortedBy { gradeDetailsWithAverage -> gradeDetailsWithAverage.subject.lowercase() }
|
gradeDetailsWithAverage.grades.maxByOrNull { it.date }?.date
|
||||||
|
}
|
||||||
|
ALPHABETIC -> gradeSubjects.sortedBy { gradeDetailsWithAverage ->
|
||||||
|
gradeDetailsWithAverage.subject.lowercase()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.map { (subject, average, points, _, grades) ->
|
.map { (subject, average, points, _, grades) ->
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
package io.github.wulkanowy.ui.modules.grade.details
|
package io.github.wulkanowy.ui.modules.grade.details
|
||||||
|
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
import io.github.wulkanowy.ui.modules.grade.GradeExpandMode
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
|
import io.github.wulkanowy.data.enums.GradeExpandMode
|
||||||
import io.github.wulkanowy.ui.base.BaseView
|
import io.github.wulkanowy.ui.base.BaseView
|
||||||
|
|
||||||
interface GradeDetailsView : BaseView {
|
interface GradeDetailsView : BaseView {
|
||||||
@ -10,7 +11,7 @@ interface GradeDetailsView : BaseView {
|
|||||||
|
|
||||||
fun initView()
|
fun initView()
|
||||||
|
|
||||||
fun updateData(data: List<GradeDetailsItem>, expandMode: GradeExpandMode, gradeColorTheme: String)
|
fun updateData(data: List<GradeDetailsItem>, expandMode: GradeExpandMode, gradeColorTheme: GradeColorTheme)
|
||||||
|
|
||||||
fun updateItem(item: Grade, position: Int)
|
fun updateItem(item: Grade, position: Int)
|
||||||
|
|
||||||
@ -22,7 +23,7 @@ interface GradeDetailsView : BaseView {
|
|||||||
|
|
||||||
fun collapseAllItems()
|
fun collapseAllItems()
|
||||||
|
|
||||||
fun showGradeDialog(grade: Grade, colorScheme: String)
|
fun showGradeDialog(grade: Grade, colorTheme: GradeColorTheme)
|
||||||
|
|
||||||
fun showContent(show: Boolean)
|
fun showContent(show: Boolean)
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@ import io.github.wulkanowy.R
|
|||||||
import io.github.wulkanowy.data.db.entities.GradePartialStatistics
|
import io.github.wulkanowy.data.db.entities.GradePartialStatistics
|
||||||
import io.github.wulkanowy.data.db.entities.GradePointsStatistics
|
import io.github.wulkanowy.data.db.entities.GradePointsStatistics
|
||||||
import io.github.wulkanowy.data.db.entities.GradeSemesterStatistics
|
import io.github.wulkanowy.data.db.entities.GradeSemesterStatistics
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.data.pojos.GradeStatisticsItem
|
import io.github.wulkanowy.data.pojos.GradeStatisticsItem
|
||||||
import io.github.wulkanowy.databinding.ItemGradeStatisticsBarBinding
|
import io.github.wulkanowy.databinding.ItemGradeStatisticsBarBinding
|
||||||
import io.github.wulkanowy.databinding.ItemGradeStatisticsHeaderBinding
|
import io.github.wulkanowy.databinding.ItemGradeStatisticsHeaderBinding
|
||||||
@ -34,7 +35,7 @@ class GradeStatisticsAdapter @Inject constructor() :
|
|||||||
|
|
||||||
var items = emptyList<GradeStatisticsItem>()
|
var items = emptyList<GradeStatisticsItem>()
|
||||||
|
|
||||||
var theme: String = "vulcan"
|
lateinit var gradeColorTheme: GradeColorTheme
|
||||||
|
|
||||||
var showAllSubjectsOnList: Boolean = false
|
var showAllSubjectsOnList: Boolean = false
|
||||||
|
|
||||||
@ -156,8 +157,8 @@ class GradeStatisticsAdapter @Inject constructor() :
|
|||||||
visibility = if (items.size == 1 || !showAllSubjectsOnList) GONE else VISIBLE
|
visibility = if (items.size == 1 || !showAllSubjectsOnList) GONE else VISIBLE
|
||||||
}
|
}
|
||||||
|
|
||||||
val gradeColors = when (theme) {
|
val gradeColors = when (gradeColorTheme) {
|
||||||
"vulcan" -> vulcanGradeColors
|
GradeColorTheme.VULCAN -> vulcanGradeColors
|
||||||
else -> materialGradeColors
|
else -> materialGradeColors
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@ import android.widget.TextView
|
|||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
import dagger.hilt.android.AndroidEntryPoint
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.data.pojos.GradeStatisticsItem
|
import io.github.wulkanowy.data.pojos.GradeStatisticsItem
|
||||||
import io.github.wulkanowy.databinding.FragmentGradeStatisticsBinding
|
import io.github.wulkanowy.databinding.FragmentGradeStatisticsBinding
|
||||||
import io.github.wulkanowy.ui.base.BaseFragment
|
import io.github.wulkanowy.ui.base.BaseFragment
|
||||||
@ -90,12 +91,12 @@ class GradeStatisticsFragment :
|
|||||||
|
|
||||||
override fun updateData(
|
override fun updateData(
|
||||||
newItems: List<GradeStatisticsItem>,
|
newItems: List<GradeStatisticsItem>,
|
||||||
newTheme: String,
|
newTheme: GradeColorTheme,
|
||||||
showAllSubjectsOnStatisticsList: Boolean
|
showAllSubjectsOnStatisticsList: Boolean
|
||||||
) {
|
) {
|
||||||
with(statisticsAdapter) {
|
with(statisticsAdapter) {
|
||||||
showAllSubjectsOnList = showAllSubjectsOnStatisticsList
|
showAllSubjectsOnList = showAllSubjectsOnStatisticsList
|
||||||
theme = newTheme
|
gradeColorTheme = newTheme
|
||||||
items = newItems
|
items = newItems
|
||||||
notifyDataSetChanged()
|
notifyDataSetChanged()
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package io.github.wulkanowy.ui.modules.grade.statistics
|
package io.github.wulkanowy.ui.modules.grade.statistics
|
||||||
|
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.data.pojos.GradeStatisticsItem
|
import io.github.wulkanowy.data.pojos.GradeStatisticsItem
|
||||||
import io.github.wulkanowy.ui.base.BaseView
|
import io.github.wulkanowy.ui.base.BaseView
|
||||||
|
|
||||||
@ -15,7 +16,7 @@ interface GradeStatisticsView : BaseView {
|
|||||||
|
|
||||||
fun updateData(
|
fun updateData(
|
||||||
newItems: List<GradeStatisticsItem>,
|
newItems: List<GradeStatisticsItem>,
|
||||||
newTheme: String,
|
newTheme: GradeColorTheme,
|
||||||
showAllSubjectsOnStatisticsList: Boolean
|
showAllSubjectsOnStatisticsList: Boolean
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -52,6 +52,8 @@ class LoginFormPresenter @Inject constructor(
|
|||||||
clearHostError()
|
clearHostError()
|
||||||
if (formHostValue.contains("fakelog")) {
|
if (formHostValue.contains("fakelog")) {
|
||||||
setCredentials("jan@fakelog.cf", "jan123")
|
setCredentials("jan@fakelog.cf", "jan123")
|
||||||
|
} else if (formUsernameValue == "jan@fakelog.cf" && formPassValue == "jan123") {
|
||||||
|
setCredentials("", "")
|
||||||
}
|
}
|
||||||
updateUsernameLabel()
|
updateUsernameLabel()
|
||||||
}
|
}
|
||||||
|
@ -56,7 +56,7 @@ class SendMessagePresenter @Inject constructor(
|
|||||||
}
|
}
|
||||||
message?.let {
|
message?.let {
|
||||||
setSubject(when (reply) {
|
setSubject(when (reply) {
|
||||||
true -> "RE: "
|
true -> "Re: "
|
||||||
else -> "FW: "
|
else -> "FW: "
|
||||||
} + message.subject)
|
} + message.subject)
|
||||||
if (preferencesRepository.fillMessageContent || reply != true) {
|
if (preferencesRepository.fillMessageContent || reply != true) {
|
||||||
|
@ -74,7 +74,7 @@ class SchoolAnnouncementPresenter @Inject constructor(
|
|||||||
Status.SUCCESS -> {
|
Status.SUCCESS -> {
|
||||||
Timber.i("Loading School announcement result: Success")
|
Timber.i("Loading School announcement result: Success")
|
||||||
view?.apply {
|
view?.apply {
|
||||||
updateData(it.data!!.sortedByDescending { item -> item.date })
|
updateData(it.data!!)
|
||||||
showEmpty(it.data.isEmpty())
|
showEmpty(it.data.isEmpty())
|
||||||
showErrorView(false)
|
showErrorView(false)
|
||||||
showContent(it.data.isNotEmpty())
|
showContent(it.data.isNotEmpty())
|
||||||
|
@ -12,6 +12,7 @@ import androidx.recyclerview.widget.DiffUtil
|
|||||||
import androidx.recyclerview.widget.RecyclerView
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Timetable
|
import io.github.wulkanowy.data.db.entities.Timetable
|
||||||
|
import io.github.wulkanowy.data.enums.TimetableMode
|
||||||
import io.github.wulkanowy.databinding.ItemTimetableBinding
|
import io.github.wulkanowy.databinding.ItemTimetableBinding
|
||||||
import io.github.wulkanowy.databinding.ItemTimetableSmallBinding
|
import io.github.wulkanowy.databinding.ItemTimetableSmallBinding
|
||||||
import io.github.wulkanowy.utils.getThemeAttrColor
|
import io.github.wulkanowy.utils.getThemeAttrColor
|
||||||
@ -35,7 +36,7 @@ class TimetableAdapter @Inject constructor() : RecyclerView.Adapter<RecyclerView
|
|||||||
|
|
||||||
var onClickListener: (Timetable) -> Unit = {}
|
var onClickListener: (Timetable) -> Unit = {}
|
||||||
|
|
||||||
private var showWholeClassPlan: String = "no"
|
private var showWholeClassPlan = TimetableMode.ONLY_CURRENT_GROUP
|
||||||
|
|
||||||
private var showGroupsInPlan: Boolean = false
|
private var showGroupsInPlan: Boolean = false
|
||||||
|
|
||||||
@ -47,7 +48,7 @@ class TimetableAdapter @Inject constructor() : RecyclerView.Adapter<RecyclerView
|
|||||||
|
|
||||||
fun submitList(
|
fun submitList(
|
||||||
newTimetable: List<Timetable>,
|
newTimetable: List<Timetable>,
|
||||||
showWholeClassPlan: String = this.showWholeClassPlan,
|
showWholeClassPlan: TimetableMode = this.showWholeClassPlan,
|
||||||
showGroupsInPlan: Boolean = this.showGroupsInPlan,
|
showGroupsInPlan: Boolean = this.showGroupsInPlan,
|
||||||
showTimers: Boolean = this.showTimers
|
showTimers: Boolean = this.showTimers
|
||||||
) {
|
) {
|
||||||
@ -87,7 +88,7 @@ class TimetableAdapter @Inject constructor() : RecyclerView.Adapter<RecyclerView
|
|||||||
override fun getItemCount() = items.size
|
override fun getItemCount() = items.size
|
||||||
|
|
||||||
override fun getItemViewType(position: Int) = when {
|
override fun getItemViewType(position: Int) = when {
|
||||||
!items[position].isStudentPlan && showWholeClassPlan == "small" -> ViewType.ITEM_SMALL.ordinal
|
!items[position].isStudentPlan && showWholeClassPlan == TimetableMode.SMALL_OTHER_GROUP -> ViewType.ITEM_SMALL.ordinal
|
||||||
else -> ViewType.ITEM_NORMAL.ordinal
|
else -> ViewType.ITEM_NORMAL.ordinal
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@ import com.google.android.material.datepicker.MaterialDatePicker
|
|||||||
import dagger.hilt.android.AndroidEntryPoint
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Timetable
|
import io.github.wulkanowy.data.db.entities.Timetable
|
||||||
|
import io.github.wulkanowy.data.enums.TimetableMode
|
||||||
import io.github.wulkanowy.databinding.FragmentTimetableBinding
|
import io.github.wulkanowy.databinding.FragmentTimetableBinding
|
||||||
import io.github.wulkanowy.ui.base.BaseFragment
|
import io.github.wulkanowy.ui.base.BaseFragment
|
||||||
import io.github.wulkanowy.ui.modules.main.MainActivity
|
import io.github.wulkanowy.ui.modules.main.MainActivity
|
||||||
@ -115,7 +116,7 @@ class TimetableFragment : BaseFragment<FragmentTimetableBinding>(R.layout.fragme
|
|||||||
|
|
||||||
override fun updateData(
|
override fun updateData(
|
||||||
data: List<Timetable>,
|
data: List<Timetable>,
|
||||||
showWholeClassPlanType: String,
|
showWholeClassPlanType: TimetableMode,
|
||||||
showGroupsInPlanType: Boolean,
|
showGroupsInPlanType: Boolean,
|
||||||
showTimetableTimers: Boolean
|
showTimetableTimers: Boolean
|
||||||
) {
|
) {
|
||||||
|
@ -3,6 +3,7 @@ package io.github.wulkanowy.ui.modules.timetable
|
|||||||
import android.annotation.SuppressLint
|
import android.annotation.SuppressLint
|
||||||
import io.github.wulkanowy.data.Status
|
import io.github.wulkanowy.data.Status
|
||||||
import io.github.wulkanowy.data.db.entities.Timetable
|
import io.github.wulkanowy.data.db.entities.Timetable
|
||||||
|
import io.github.wulkanowy.data.enums.TimetableMode
|
||||||
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
||||||
import io.github.wulkanowy.data.repositories.SemesterRepository
|
import io.github.wulkanowy.data.repositories.SemesterRepository
|
||||||
import io.github.wulkanowy.data.repositories.StudentRepository
|
import io.github.wulkanowy.data.repositories.StudentRepository
|
||||||
@ -197,7 +198,7 @@ class TimetablePresenter @Inject constructor(
|
|||||||
}
|
}
|
||||||
|
|
||||||
private fun createItems(items: List<Timetable>) = items.filter { item ->
|
private fun createItems(items: List<Timetable>) = items.filter { item ->
|
||||||
if (prefRepository.showWholeClassPlan == "no") item.isStudentPlan else true
|
if (prefRepository.showWholeClassPlan == TimetableMode.ONLY_CURRENT_GROUP) item.isStudentPlan else true
|
||||||
}.sortedWith(compareBy({ item -> item.number }, { item -> !item.isStudentPlan }))
|
}.sortedWith(compareBy({ item -> item.number }, { item -> !item.isStudentPlan }))
|
||||||
|
|
||||||
private fun showErrorViewOnError(message: String, error: Throwable) {
|
private fun showErrorViewOnError(message: String, error: Throwable) {
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package io.github.wulkanowy.ui.modules.timetable
|
package io.github.wulkanowy.ui.modules.timetable
|
||||||
|
|
||||||
import io.github.wulkanowy.data.db.entities.Timetable
|
import io.github.wulkanowy.data.db.entities.Timetable
|
||||||
|
import io.github.wulkanowy.data.enums.TimetableMode
|
||||||
import io.github.wulkanowy.ui.base.BaseView
|
import io.github.wulkanowy.ui.base.BaseView
|
||||||
import java.time.LocalDate
|
import java.time.LocalDate
|
||||||
|
|
||||||
@ -12,7 +13,12 @@ interface TimetableView : BaseView {
|
|||||||
|
|
||||||
fun initView()
|
fun initView()
|
||||||
|
|
||||||
fun updateData(data: List<Timetable>, showWholeClassPlanType: String, showGroupsInPlanType: Boolean, showTimetableTimers: Boolean)
|
fun updateData(
|
||||||
|
data: List<Timetable>,
|
||||||
|
showWholeClassPlanType: TimetableMode,
|
||||||
|
showGroupsInPlanType: Boolean,
|
||||||
|
showTimetableTimers: Boolean
|
||||||
|
)
|
||||||
|
|
||||||
fun updateNavigationDay(date: String)
|
fun updateNavigationDay(date: String)
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@ import android.widget.RemoteViewsService
|
|||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.SharedPrefProvider
|
import io.github.wulkanowy.data.db.SharedPrefProvider
|
||||||
import io.github.wulkanowy.data.db.entities.Timetable
|
import io.github.wulkanowy.data.db.entities.Timetable
|
||||||
|
import io.github.wulkanowy.data.enums.TimetableMode
|
||||||
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
import io.github.wulkanowy.data.repositories.PreferencesRepository
|
||||||
import io.github.wulkanowy.data.repositories.SemesterRepository
|
import io.github.wulkanowy.data.repositories.SemesterRepository
|
||||||
import io.github.wulkanowy.data.repositories.StudentRepository
|
import io.github.wulkanowy.data.repositories.StudentRepository
|
||||||
@ -88,7 +89,7 @@ class TimetableWidgetFactory(
|
|||||||
|
|
||||||
private fun getItemLayout(lesson: Timetable): Int {
|
private fun getItemLayout(lesson: Timetable): Int {
|
||||||
return when {
|
return when {
|
||||||
prefRepository.showWholeClassPlan == "small" && !lesson.isStudentPlan -> {
|
prefRepository.showWholeClassPlan == TimetableMode.SMALL_OTHER_GROUP && !lesson.isStudentPlan -> {
|
||||||
if (savedCurrentTheme == 0L) R.layout.item_widget_timetable_small
|
if (savedCurrentTheme == 0L) R.layout.item_widget_timetable_small
|
||||||
else R.layout.item_widget_timetable_small_dark
|
else R.layout.item_widget_timetable_small_dark
|
||||||
}
|
}
|
||||||
@ -109,7 +110,11 @@ class TimetableWidgetFactory(
|
|||||||
timetableRepository.getTimetable(student, semester, date, date, false)
|
timetableRepository.getTimetable(student, semester, date, date, false)
|
||||||
.toFirstResult().data?.lessons.orEmpty()
|
.toFirstResult().data?.lessons.orEmpty()
|
||||||
.sortedWith(compareBy({ it.number }, { !it.isStudentPlan }))
|
.sortedWith(compareBy({ it.number }, { !it.isStudentPlan }))
|
||||||
.filter { if (prefRepository.showWholeClassPlan == "no") it.isStudentPlan else true }
|
.filter {
|
||||||
|
if (prefRepository.showWholeClassPlan == TimetableMode.ONLY_CURRENT_GROUP) {
|
||||||
|
it.isStudentPlan
|
||||||
|
} else true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} catch (e: Exception) {
|
} catch (e: Exception) {
|
||||||
Timber.e(e, "An error has occurred in timetable widget factory")
|
Timber.e(e, "An error has occurred in timetable widget factory")
|
||||||
@ -124,8 +129,14 @@ class TimetableWidgetFactory(
|
|||||||
return RemoteViews(context.packageName, getItemLayout(lesson)).apply {
|
return RemoteViews(context.packageName, getItemLayout(lesson)).apply {
|
||||||
setTextViewText(R.id.timetableWidgetItemSubject, lesson.subject)
|
setTextViewText(R.id.timetableWidgetItemSubject, lesson.subject)
|
||||||
setTextViewText(R.id.timetableWidgetItemNumber, lesson.number.toString())
|
setTextViewText(R.id.timetableWidgetItemNumber, lesson.number.toString())
|
||||||
setTextViewText(R.id.timetableWidgetItemTimeStart, lesson.start.toFormattedString("HH:mm"))
|
setTextViewText(
|
||||||
setTextViewText(R.id.timetableWidgetItemTimeFinish, lesson.end.toFormattedString("HH:mm"))
|
R.id.timetableWidgetItemTimeStart,
|
||||||
|
lesson.start.toFormattedString("HH:mm")
|
||||||
|
)
|
||||||
|
setTextViewText(
|
||||||
|
R.id.timetableWidgetItemTimeFinish,
|
||||||
|
lesson.end.toFormattedString("HH:mm")
|
||||||
|
)
|
||||||
|
|
||||||
updateDescription(this, lesson)
|
updateDescription(this, lesson)
|
||||||
|
|
||||||
@ -156,11 +167,16 @@ class TimetableWidgetFactory(
|
|||||||
|
|
||||||
private fun updateStylesCanceled(remoteViews: RemoteViews) {
|
private fun updateStylesCanceled(remoteViews: RemoteViews) {
|
||||||
with(remoteViews) {
|
with(remoteViews) {
|
||||||
setInt(R.id.timetableWidgetItemSubject, "setPaintFlags",
|
setInt(
|
||||||
STRIKE_THRU_TEXT_FLAG or ANTI_ALIAS_FLAG)
|
R.id.timetableWidgetItemSubject, "setPaintFlags",
|
||||||
|
STRIKE_THRU_TEXT_FLAG or ANTI_ALIAS_FLAG
|
||||||
|
)
|
||||||
setTextColor(R.id.timetableWidgetItemNumber, context.getCompatColor(primaryColor!!))
|
setTextColor(R.id.timetableWidgetItemNumber, context.getCompatColor(primaryColor!!))
|
||||||
setTextColor(R.id.timetableWidgetItemSubject, context.getCompatColor(primaryColor!!))
|
setTextColor(R.id.timetableWidgetItemSubject, context.getCompatColor(primaryColor!!))
|
||||||
setTextColor(R.id.timetableWidgetItemDescription, context.getCompatColor(primaryColor!!))
|
setTextColor(
|
||||||
|
R.id.timetableWidgetItemDescription,
|
||||||
|
context.getCompatColor(primaryColor!!)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -168,7 +184,10 @@ class TimetableWidgetFactory(
|
|||||||
with(remoteViews) {
|
with(remoteViews) {
|
||||||
setInt(R.id.timetableWidgetItemSubject, "setPaintFlags", ANTI_ALIAS_FLAG)
|
setInt(R.id.timetableWidgetItemSubject, "setPaintFlags", ANTI_ALIAS_FLAG)
|
||||||
setTextColor(R.id.timetableWidgetItemSubject, context.getCompatColor(textColor!!))
|
setTextColor(R.id.timetableWidgetItemSubject, context.getCompatColor(textColor!!))
|
||||||
setTextColor(R.id.timetableWidgetItemDescription, context.getCompatColor(timetableChangeColor!!))
|
setTextColor(
|
||||||
|
R.id.timetableWidgetItemDescription,
|
||||||
|
context.getCompatColor(timetableChangeColor!!)
|
||||||
|
)
|
||||||
|
|
||||||
updateNotCanceledLessonNumberColor(this, lesson)
|
updateNotCanceledLessonNumberColor(this, lesson)
|
||||||
updateNotCanceledSubjectColor(this, lesson)
|
updateNotCanceledSubjectColor(this, lesson)
|
||||||
@ -180,37 +199,53 @@ class TimetableWidgetFactory(
|
|||||||
}
|
}
|
||||||
|
|
||||||
private fun updateNotCanceledLessonNumberColor(remoteViews: RemoteViews, lesson: Timetable) {
|
private fun updateNotCanceledLessonNumberColor(remoteViews: RemoteViews, lesson: Timetable) {
|
||||||
remoteViews.setTextColor(R.id.timetableWidgetItemNumber, context.getCompatColor(
|
remoteViews.setTextColor(
|
||||||
if (lesson.changes || (lesson.info.isNotBlank() && !lesson.canceled)) timetableChangeColor!!
|
R.id.timetableWidgetItemNumber, context.getCompatColor(
|
||||||
else textColor!!
|
if (lesson.changes || (lesson.info.isNotBlank() && !lesson.canceled)) timetableChangeColor!!
|
||||||
))
|
else textColor!!
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun updateNotCanceledSubjectColor(remoteViews: RemoteViews, lesson: Timetable) {
|
private fun updateNotCanceledSubjectColor(remoteViews: RemoteViews, lesson: Timetable) {
|
||||||
remoteViews.setTextColor(R.id.timetableWidgetItemSubject, context.getCompatColor(
|
remoteViews.setTextColor(
|
||||||
if (lesson.subjectOld.isNotBlank() && lesson.subject != lesson.subjectOld) timetableChangeColor!!
|
R.id.timetableWidgetItemSubject, context.getCompatColor(
|
||||||
else textColor!!
|
if (lesson.subjectOld.isNotBlank() && lesson.subject != lesson.subjectOld) timetableChangeColor!!
|
||||||
))
|
else textColor!!
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun updateNotCanceledRoom(remoteViews: RemoteViews, lesson: Timetable, teacherChange: Boolean) {
|
private fun updateNotCanceledRoom(
|
||||||
|
remoteViews: RemoteViews,
|
||||||
|
lesson: Timetable,
|
||||||
|
teacherChange: Boolean
|
||||||
|
) {
|
||||||
with(remoteViews) {
|
with(remoteViews) {
|
||||||
if (lesson.room.isNotBlank()) {
|
if (lesson.room.isNotBlank()) {
|
||||||
setTextViewText(R.id.timetableWidgetItemRoom,
|
setTextViewText(
|
||||||
|
R.id.timetableWidgetItemRoom,
|
||||||
if (teacherChange) lesson.room
|
if (teacherChange) lesson.room
|
||||||
else "${context.getString(R.string.timetable_room)} ${lesson.room}"
|
else "${context.getString(R.string.timetable_room)} ${lesson.room}"
|
||||||
)
|
)
|
||||||
|
|
||||||
setTextColor(R.id.timetableWidgetItemRoom, context.getCompatColor(
|
setTextColor(
|
||||||
if (lesson.roomOld.isNotBlank() && lesson.room != lesson.roomOld) timetableChangeColor!!
|
R.id.timetableWidgetItemRoom, context.getCompatColor(
|
||||||
else textColor!!
|
if (lesson.roomOld.isNotBlank() && lesson.room != lesson.roomOld) timetableChangeColor!!
|
||||||
))
|
else textColor!!
|
||||||
|
)
|
||||||
|
)
|
||||||
} else setTextViewText(R.id.timetableWidgetItemRoom, "")
|
} else setTextViewText(R.id.timetableWidgetItemRoom, "")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun updateNotCanceledTeacher(remoteViews: RemoteViews, lesson: Timetable, teacherChange: Boolean) {
|
private fun updateNotCanceledTeacher(
|
||||||
remoteViews.setTextViewText(R.id.timetableWidgetItemTeacher,
|
remoteViews: RemoteViews,
|
||||||
|
lesson: Timetable,
|
||||||
|
teacherChange: Boolean
|
||||||
|
) {
|
||||||
|
remoteViews.setTextViewText(
|
||||||
|
R.id.timetableWidgetItemTeacher,
|
||||||
if (teacherChange) lesson.teacher
|
if (teacherChange) lesson.teacher
|
||||||
else ""
|
else ""
|
||||||
)
|
)
|
||||||
|
@ -3,6 +3,7 @@ package io.github.wulkanowy.utils
|
|||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
import io.github.wulkanowy.data.db.entities.GradeSummary
|
import io.github.wulkanowy.data.db.entities.GradeSummary
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.github.wulkanowy.sdk.scrapper.grades.isGradeValid
|
import io.github.wulkanowy.sdk.scrapper.grades.isGradeValid
|
||||||
|
|
||||||
fun List<Grade>.calcAverage(isOptionalArithmeticAverage: Boolean): Double {
|
fun List<Grade>.calcAverage(isOptionalArithmeticAverage: Boolean): Double {
|
||||||
@ -37,28 +38,6 @@ fun List<GradeSummary>.calcFinalAverage(plusModifier: Double, minusModifier: Dou
|
|||||||
.average()
|
.average()
|
||||||
.let { if (it.isNaN()) 0.0 else it }
|
.let { if (it.isNaN()) 0.0 else it }
|
||||||
|
|
||||||
fun Grade.getBackgroundColor(theme: String) = when (theme) {
|
|
||||||
"grade_color" -> getGradeColor()
|
|
||||||
"material" -> when (value.toInt()) {
|
|
||||||
6 -> R.color.grade_material_six
|
|
||||||
5 -> R.color.grade_material_five
|
|
||||||
4 -> R.color.grade_material_four
|
|
||||||
3 -> R.color.grade_material_three
|
|
||||||
2 -> R.color.grade_material_two
|
|
||||||
1 -> R.color.grade_material_one
|
|
||||||
else -> R.color.grade_material_default
|
|
||||||
}
|
|
||||||
else -> when (value.toInt()) {
|
|
||||||
6 -> R.color.grade_vulcan_six
|
|
||||||
5 -> R.color.grade_vulcan_five
|
|
||||||
4 -> R.color.grade_vulcan_four
|
|
||||||
3 -> R.color.grade_vulcan_three
|
|
||||||
2 -> R.color.grade_vulcan_two
|
|
||||||
1 -> R.color.grade_vulcan_one
|
|
||||||
else -> R.color.grade_vulcan_default
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fun Grade.getGradeColor() = when (color) {
|
fun Grade.getGradeColor() = when (color) {
|
||||||
"000000" -> R.color.grade_black
|
"000000" -> R.color.grade_black
|
||||||
"F04C4C" -> R.color.grade_red
|
"F04C4C" -> R.color.grade_red
|
||||||
@ -83,3 +62,25 @@ fun Grade.changeModifier(plusModifier: Double, minusModifier: Double) = when {
|
|||||||
modifier < 0 -> copy(modifier = -minusModifier)
|
modifier < 0 -> copy(modifier = -minusModifier)
|
||||||
else -> this
|
else -> this
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun Grade.getBackgroundColor(theme: GradeColorTheme) = when (theme) {
|
||||||
|
GradeColorTheme.GRADE_COLOR -> getGradeColor()
|
||||||
|
GradeColorTheme.MATERIAL -> when (value.toInt()) {
|
||||||
|
6 -> R.color.grade_material_six
|
||||||
|
5 -> R.color.grade_material_five
|
||||||
|
4 -> R.color.grade_material_four
|
||||||
|
3 -> R.color.grade_material_three
|
||||||
|
2 -> R.color.grade_material_two
|
||||||
|
1 -> R.color.grade_material_one
|
||||||
|
else -> R.color.grade_material_default
|
||||||
|
}
|
||||||
|
GradeColorTheme.VULCAN -> when (value.toInt()) {
|
||||||
|
6 -> R.color.grade_vulcan_six
|
||||||
|
5 -> R.color.grade_vulcan_five
|
||||||
|
4 -> R.color.grade_vulcan_four
|
||||||
|
3 -> R.color.grade_vulcan_three
|
||||||
|
2 -> R.color.grade_vulcan_two
|
||||||
|
1 -> R.color.grade_vulcan_one
|
||||||
|
else -> R.color.grade_vulcan_default
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
Wersja 1.4.3
|
Wersja 1.4.4
|
||||||
|
|
||||||
Naprawiliśmy drobne problemy ze stabilnością oraz małą usterkę w wyszukiwarce wiadomości.
|
- naprawiliśmy logowanie do Gdańskiej Platformy Edukacyjnej
|
||||||
Wszystko po to, aby jeszcze bardziej podnieść komfort z używania aplikacji!
|
- naprawiliśmy sortowanie ocen oraz ogłoszeń
|
||||||
|
|
||||||
Pełna lista zmian: https://github.com/wulkanowy/wulkanowy/releases
|
Pełna lista zmian: https://github.com/wulkanowy/wulkanowy/releases
|
||||||
|
@ -553,18 +553,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Brzy:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Brzy:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">První:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">První:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Teď:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Teď:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">za %1$d minutu</item>
|
|
||||||
<item quantity="few">za %1$d minuty</item>
|
|
||||||
<item quantity="many">za %1$d minut</item>
|
|
||||||
<item quantity="other">za %1$d minut</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">ještě %1$d minutu</item>
|
|
||||||
<item quantity="few">ještě %1$d minuty</item>
|
|
||||||
<item quantity="many">ještě %1$d minut</item>
|
|
||||||
<item quantity="other">ještě %1$d minut</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">Konec lekcí</string>
|
<string name="dashboard_timetable_second_lesson_value_end">Konec lekcí</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Další:</string>
|
<string name="dashboard_timetable_second_lessons_title">Další:</string>
|
||||||
<string name="dashboard_timetable_third_title">Později:</string>
|
<string name="dashboard_timetable_third_title">Později:</string>
|
||||||
|
@ -477,14 +477,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Bald:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Bald:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">Erstens:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">Erstens:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Jetzt:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Jetzt:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">in %1$d Minute</item>
|
|
||||||
<item quantity="other">in %1$d Minuten</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">Noch %1$d Minute</item>
|
|
||||||
<item quantity="other">Noch %1$d Minuten</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">Ende der Lektion</string>
|
<string name="dashboard_timetable_second_lesson_value_end">Ende der Lektion</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Nächste:</string>
|
<string name="dashboard_timetable_second_lessons_title">Nächste:</string>
|
||||||
<string name="dashboard_timetable_third_title">Später:</string>
|
<string name="dashboard_timetable_third_title">Später:</string>
|
||||||
|
@ -553,18 +553,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Wkrótce:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Wkrótce:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">Pierwsza:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">Pierwsza:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Teraz:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Teraz:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">za %1$d minutę</item>
|
|
||||||
<item quantity="few">za %1$d minuty</item>
|
|
||||||
<item quantity="many">za %1$d minut</item>
|
|
||||||
<item quantity="other">za %1$d minut</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">jeszcze %1$d minuta</item>
|
|
||||||
<item quantity="few">jeszcze %1$d minuty</item>
|
|
||||||
<item quantity="many">jeszcze %1$d minut</item>
|
|
||||||
<item quantity="other">jeszcze %1$d minut</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">Koniec lekcji</string>
|
<string name="dashboard_timetable_second_lesson_value_end">Koniec lekcji</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Następnie:</string>
|
<string name="dashboard_timetable_second_lessons_title">Następnie:</string>
|
||||||
<string name="dashboard_timetable_third_title">Później:</string>
|
<string name="dashboard_timetable_third_title">Później:</string>
|
||||||
|
@ -553,18 +553,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Скоро:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Скоро:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">Первый:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">Первый:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Сейчас:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Сейчас:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">через %1$d минуту</item>
|
|
||||||
<item quantity="few">через %1$d минуту</item>
|
|
||||||
<item quantity="many">через %1$d минуту</item>
|
|
||||||
<item quantity="other">через %1$d минут</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">Еще %1$d минута</item>
|
|
||||||
<item quantity="few">Еще %1$d минута</item>
|
|
||||||
<item quantity="many">Еще %1$d минута</item>
|
|
||||||
<item quantity="other">Ещё %1$d минут</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">Окончание уроков</string>
|
<string name="dashboard_timetable_second_lesson_value_end">Окончание уроков</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Далее:</string>
|
<string name="dashboard_timetable_second_lessons_title">Далее:</string>
|
||||||
<string name="dashboard_timetable_third_title">Позднее:</string>
|
<string name="dashboard_timetable_third_title">Позднее:</string>
|
||||||
|
@ -553,18 +553,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Čoskoro:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Čoskoro:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">Prvá:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">Prvá:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Teraz:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Teraz:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">za %1$d minútu</item>
|
|
||||||
<item quantity="few">za %1$d minúty</item>
|
|
||||||
<item quantity="many">za %1$d minút</item>
|
|
||||||
<item quantity="other">za %1$d minút</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">ešte %1$d minútu</item>
|
|
||||||
<item quantity="few">ešte %1$d minúty</item>
|
|
||||||
<item quantity="many">ešte %1$d minút</item>
|
|
||||||
<item quantity="other">ešte %1$d minút</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">Koniec lekcií</string>
|
<string name="dashboard_timetable_second_lesson_value_end">Koniec lekcií</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Ďalej:</string>
|
<string name="dashboard_timetable_second_lessons_title">Ďalej:</string>
|
||||||
<string name="dashboard_timetable_third_title">Neskôr:</string>
|
<string name="dashboard_timetable_third_title">Neskôr:</string>
|
||||||
|
@ -553,18 +553,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Незабаром:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Незабаром:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">Перше:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">Перше:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Зараз:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Зараз:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">через %1$d хвилину</item>
|
|
||||||
<item quantity="few">через %1$d хвилину</item>
|
|
||||||
<item quantity="many">через %1$d хвилину</item>
|
|
||||||
<item quantity="other">через %1$d хвилин</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">%1$d більше хвилини</item>
|
|
||||||
<item quantity="few">%1$d більше хвилини</item>
|
|
||||||
<item quantity="many">%1$d більше хвилини</item>
|
|
||||||
<item quantity="other">%1$d ще хвилин</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">Кінець уроків</string>
|
<string name="dashboard_timetable_second_lesson_value_end">Кінець уроків</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Далі:</string>
|
<string name="dashboard_timetable_second_lessons_title">Далі:</string>
|
||||||
<string name="dashboard_timetable_third_title">Пізніше :</string>
|
<string name="dashboard_timetable_third_title">Пізніше :</string>
|
||||||
|
@ -71,7 +71,7 @@
|
|||||||
<string name="login_contact_discord">Discord</string>
|
<string name="login_contact_discord">Discord</string>
|
||||||
<string name="login_email_intent_title">Send email</string>
|
<string name="login_email_intent_title">Send email</string>
|
||||||
<string name="login_email_subject" translatable="false">Zgłoszenie: Problemy z logowaniem</string>
|
<string name="login_email_subject" translatable="false">Zgłoszenie: Problemy z logowaniem</string>
|
||||||
<string name="login_email_text" translatable="false">Informacje o aplikacji:\n\nUrządzenie: %1$s\nWersja SDK: %2$s\nWersja aplikacji: %3$s\nDodatkowe informacje: %4$s\nOstatni błąd: %5$s\n\nPełna nazwa szkoły i klasa ucznia: </string>
|
<string name="login_email_text" translatable="false">Informacje o aplikacji:\n\nUrządzenie: %1$s\nWersja SDK: %2$s\nWersja aplikacji: %3$s\nDodatkowe informacje: %4$s\nOstatni błąd: %5$s\n\nNazwa szkoły wraz z miejscowością i numer klasy: </string>
|
||||||
<string name="login_recover_warning">Make sure you select the correct UONET+ register variation!</string>
|
<string name="login_recover_warning">Make sure you select the correct UONET+ register variation!</string>
|
||||||
<string name="login_recover_button">I forgot my password</string>
|
<string name="login_recover_button">I forgot my password</string>
|
||||||
<string name="login_recover_title">Recover your account</string>
|
<string name="login_recover_title">Recover your account</string>
|
||||||
@ -247,8 +247,8 @@
|
|||||||
<item quantity="other">New exams</item>
|
<item quantity="other">New exams</item>
|
||||||
</plurals>
|
</plurals>
|
||||||
<plurals name="exam_notify_new_item_content">
|
<plurals name="exam_notify_new_item_content">
|
||||||
<item quantity="one">You received %d new exam</item>
|
<item quantity="one">%d new exam</item>
|
||||||
<item quantity="other">You received %d new exams</item>
|
<item quantity="other">%d new exams</item>
|
||||||
</plurals>
|
</plurals>
|
||||||
<plurals name="exam_number_item">
|
<plurals name="exam_number_item">
|
||||||
<item quantity="one">%d exam</item>
|
<item quantity="one">%d exam</item>
|
||||||
@ -541,14 +541,6 @@
|
|||||||
<string name="dashboard_timetable_first_lesson_title_soon">Soon:</string>
|
<string name="dashboard_timetable_first_lesson_title_soon">Soon:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_first">First:</string>
|
<string name="dashboard_timetable_first_lesson_title_first">First:</string>
|
||||||
<string name="dashboard_timetable_first_lesson_title_now">Now:</string>
|
<string name="dashboard_timetable_first_lesson_title_now">Now:</string>
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_in_minutes">
|
|
||||||
<item quantity="one">in %1$d minute</item>
|
|
||||||
<item quantity="other">in %1$d minutes</item>
|
|
||||||
</plurals>
|
|
||||||
<plurals name="dashboard_timetable_first_lesson_time_more_minutes">
|
|
||||||
<item quantity="one">%1$d more minute</item>
|
|
||||||
<item quantity="other">%1$d more minutes</item>
|
|
||||||
</plurals>
|
|
||||||
<string name="dashboard_timetable_second_lesson_value_end">End of lessons</string>
|
<string name="dashboard_timetable_second_lesson_value_end">End of lessons</string>
|
||||||
<string name="dashboard_timetable_second_lessons_title">Next:</string>
|
<string name="dashboard_timetable_second_lessons_title">Next:</string>
|
||||||
<string name="dashboard_timetable_third_title">Later:</string>
|
<string name="dashboard_timetable_third_title">Later:</string>
|
||||||
|
@ -3,6 +3,7 @@ package io.github.wulkanowy.utils
|
|||||||
import io.github.wulkanowy.R
|
import io.github.wulkanowy.R
|
||||||
import io.github.wulkanowy.data.db.entities.Grade
|
import io.github.wulkanowy.data.db.entities.Grade
|
||||||
import io.github.wulkanowy.data.db.entities.GradeSummary
|
import io.github.wulkanowy.data.db.entities.GradeSummary
|
||||||
|
import io.github.wulkanowy.data.enums.GradeColorTheme
|
||||||
import io.mockk.MockKAnnotations
|
import io.mockk.MockKAnnotations
|
||||||
import io.mockk.impl.annotations.MockK
|
import io.mockk.impl.annotations.MockK
|
||||||
import org.junit.Assert.assertEquals
|
import org.junit.Assert.assertEquals
|
||||||
@ -46,10 +47,25 @@ class GradeExtensionTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun getBackgroundColor() {
|
fun getBackgroundColor() {
|
||||||
assertEquals(R.color.grade_material_five, createGrade(5.0).getBackgroundColor("material"))
|
assertEquals(
|
||||||
assertEquals(R.color.grade_material_five, createGrade(5.5).getBackgroundColor("material"))
|
R.color.grade_material_five, createGrade(5.0).getBackgroundColor(
|
||||||
assertEquals(R.color.grade_material_five, createGrade(5.9).getBackgroundColor("material"))
|
GradeColorTheme.MATERIAL
|
||||||
assertEquals(R.color.grade_vulcan_five, createGrade(5.9).getBackgroundColor("whatever"))
|
)
|
||||||
|
)
|
||||||
|
assertEquals(
|
||||||
|
R.color.grade_material_five, createGrade(5.5).getBackgroundColor(
|
||||||
|
GradeColorTheme.MATERIAL
|
||||||
|
)
|
||||||
|
)
|
||||||
|
assertEquals(
|
||||||
|
R.color.grade_material_five, createGrade(5.9).getBackgroundColor(
|
||||||
|
GradeColorTheme.MATERIAL
|
||||||
|
)
|
||||||
|
)
|
||||||
|
assertEquals(
|
||||||
|
R.color.grade_vulcan_five,
|
||||||
|
createGrade(5.9).getBackgroundColor(GradeColorTheme.VULCAN)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -2,7 +2,7 @@ buildscript {
|
|||||||
ext {
|
ext {
|
||||||
kotlin_version = '1.6.0'
|
kotlin_version = '1.6.0'
|
||||||
about_libraries = '8.9.4'
|
about_libraries = '8.9.4'
|
||||||
hilt_version = "2.40.2"
|
hilt_version = "2.40.5"
|
||||||
}
|
}
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
@ -13,11 +13,11 @@ buildscript {
|
|||||||
dependencies {
|
dependencies {
|
||||||
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||||
classpath "org.jetbrains.kotlin:kotlin-serialization:$kotlin_version"
|
classpath "org.jetbrains.kotlin:kotlin-serialization:$kotlin_version"
|
||||||
classpath 'com.android.tools.build:gradle:7.0.3'
|
classpath 'com.android.tools.build:gradle:7.0.4'
|
||||||
classpath "com.google.dagger:hilt-android-gradle-plugin:$hilt_version"
|
classpath "com.google.dagger:hilt-android-gradle-plugin:$hilt_version"
|
||||||
classpath 'com.google.gms:google-services:4.3.10'
|
classpath 'com.google.gms:google-services:4.3.10'
|
||||||
classpath 'com.huawei.agconnect:agcp:1.6.2.200'
|
classpath 'com.huawei.agconnect:agcp:1.6.2.300'
|
||||||
classpath 'com.google.firebase:firebase-crashlytics-gradle:2.8.0'
|
classpath 'com.google.firebase:firebase-crashlytics-gradle:2.8.1'
|
||||||
classpath "com.github.triplet.gradle:play-publisher:3.6.0"
|
classpath "com.github.triplet.gradle:play-publisher:3.6.0"
|
||||||
classpath "ru.cian:huawei-publish-gradle-plugin:1.3.0"
|
classpath "ru.cian:huawei-publish-gradle-plugin:1.3.0"
|
||||||
classpath "org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:3.3"
|
classpath "org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:3.3"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user