diff --git a/app/build.gradle b/app/build.gradle index e8899d0937..3d86aa432b 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -10,8 +10,8 @@ android { applicationId "org.ole.planet.myplanet" minSdkVersion 26 targetSdkVersion 34 - versionCode 2171 - versionName "0.21.71" + versionCode 2172 + versionName "0.21.72" ndkVersion '21.3.6528147' testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" vectorDrawables.useSupportLibrary = true diff --git a/app/src/main/java/org/ole/planet/myplanet/ui/team/TeamFragment.kt b/app/src/main/java/org/ole/planet/myplanet/ui/team/TeamFragment.kt index afaed2d3a2..31838b4df9 100644 --- a/app/src/main/java/org/ole/planet/myplanet/ui/team/TeamFragment.kt +++ b/app/src/main/java/org/ole/planet/myplanet/ui/team/TeamFragment.kt @@ -203,8 +203,9 @@ class TeamFragment : Fragment(), AdapterTeamList.OnClickTeamItem { .notEqualTo("status", "archived") .contains("name", charSequence.toString(), Case.INSENSITIVE) val (list, conditionApplied) = getList(query) + val sortedList = sortTeams(list) val adapterTeamList = AdapterTeamList( - activity as Context, list, mRealm, childFragmentManager + activity as Context, sortedList, mRealm, childFragmentManager ) adapterTeamList.setTeamListener(this@TeamFragment) fragmentTeamBinding.rvTeamList.adapter = adapterTeamList @@ -253,6 +254,17 @@ class TeamFragment : Fragment(), AdapterTeamList.OnClickTeamItem { } } + private fun sortTeams(list: List): List { + val user = user?.id + return list.sortedWith(compareByDescending { team -> + when { + RealmMyTeam.isTeamLeader(team.teamId, user, mRealm) -> 3 + team.isMyTeam(user, mRealm) -> 2 + else -> 1 + } + }) + } + override fun onEditTeam(team: RealmMyTeam?) { createTeamAlert(team!!) } @@ -261,7 +273,8 @@ class TeamFragment : Fragment(), AdapterTeamList.OnClickTeamItem { activity?.runOnUiThread { val query = mRealm.where(RealmMyTeam::class.java).isEmpty("teamId").notEqualTo("status", "archived") val (filteredList, conditionApplied) = getList(query) - val adapterTeamList = AdapterTeamList(activity as Context, filteredList, mRealm, childFragmentManager).apply { + val sortedList = sortTeams(filteredList) + val adapterTeamList = AdapterTeamList(activity as Context, sortedList, mRealm, childFragmentManager).apply { setType(type) setTeamListener(this@TeamFragment) }