Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix #1762: NavigationDrawer cancel switch profile always mark home #1816

Closed
Closed
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
57 commits
Select commit Hold shift + click to select a range
d415788
fixed major bugs
prayutsu Sep 5, 2020
519c36a
fixed marking correct last item in navigation drawer
prayutsu Sep 5, 2020
803ce83
fixed nits
prayutsu Sep 5, 2020
e3f336e
fixed lint errors
prayutsu Sep 5, 2020
1931f22
test without any marking
prayutsu Sep 6, 2020
c56d9c4
fixed almost all the bugs
prayutsu Sep 19, 2020
5098c10
tried fixing last bug
prayutsu Sep 21, 2020
0799f75
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Sep 26, 2020
245014b
fixed all the bugs
prayutsu Sep 27, 2020
80a5a8f
removed extra code
prayutsu Sep 28, 2020
f9a8600
Nit change
prayutsu Sep 28, 2020
2f9d2b7
test for reason of admin controls bug
prayutsu Sep 28, 2020
d271dfe
Optimized code
prayutsu Sep 28, 2020
99215f8
fixed lint error
prayutsu Sep 28, 2020
cf488c5
fixed lint error
prayutsu Sep 28, 2020
f5d2fcb
fixed reviewed changes
prayutsu Oct 9, 2020
b071e2b
fixed ktlint failures
prayutsu Oct 9, 2020
56d5250
fixed suggested changes
prayutsu Oct 9, 2020
78e2d62
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Dec 20, 2020
7eccac7
add few test cases
prayutsu Dec 24, 2020
8e4fdc0
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Dec 24, 2020
0ef2f5a
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Jan 6, 2021
bfe6192
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Jan 11, 2021
5d4f8ee
Add more test cases
prayutsu Jan 11, 2021
6639420
Fix imports
prayutsu Jan 11, 2021
0c8b43d
Fix Administrator Controls test cases
prayutsu Jan 12, 2021
007407d
Uncomment All other test cases
prayutsu Jan 12, 2021
05f48f0
Make a function to uncheck all items when Administrator Controls is c…
prayutsu Jan 13, 2021
a1777e5
Fix lint
prayutsu Jan 13, 2021
f9f086c
Fix lint
prayutsu Jan 13, 2021
6c477fc
Improve code
prayutsu Jan 15, 2021
0733811
Replace .isCheckable with .isChecked
prayutsu Jan 16, 2021
72a3fe2
Improve quality of the code by using function
prayutsu Jan 19, 2021
544c814
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Jan 19, 2021
b23869f
Add test cases related to color for all menu items
prayutsu Jan 19, 2021
b03b57e
Restore deleted line
prayutsu Jan 19, 2021
38c09c8
Add @RunOn(TestPlatform.ESPRESSO) notation to added test cases
prayutsu Jan 22, 2021
52ae75d
Fix lint errors
prayutsu Jan 22, 2021
de003c6
Fix suggested changes
prayutsu Jan 22, 2021
08f59d3
Fix lint errors
prayutsu Jan 22, 2021
6fba236
Fix the names of the new test cases
prayutsu Jan 22, 2021
cc45211
Fix suggested changes
prayutsu Jan 22, 2021
72d243c
Fix nits
prayutsu Jan 26, 2021
3774af2
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Jan 26, 2021
4c7f798
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Jan 28, 2021
08deb4b
Correct dialog box dependency
prayutsu Jan 29, 2021
91d75b1
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Feb 2, 2021
6ffd6ed
Replace different keys with a single proto object.
prayutsu Feb 3, 2021
caf0f48
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Feb 3, 2021
93828e2
Fix lint and bazel build errors.
prayutsu Feb 3, 2021
4ff38db
Add ":arguments_java_proto_lite" in the android_library in BUILD.bazel
prayutsu Feb 3, 2021
d65710b
Improve comments' explanation and make the variable names consistent.
prayutsu Feb 3, 2021
381509d
Try implementing suggested changes.
prayutsu Feb 5, 2021
8ec8a2d
Merge branch 'develop' of https://github.com/oppia/oppia-android into…
prayutsu Feb 5, 2021
d9a4608
Fix lint errors.
prayutsu Feb 5, 2021
fe5191f
Make use of enum defined in arguments.proto
prayutsu Feb 5, 2021
b29f8e5
Fix protobuf error.
prayutsu Feb 5, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -17,16 +17,26 @@ class ExitProfileDialogFragment : DialogFragment() {
// TODO(#1655): Re-restrict access to fields in tests post-Gradle.
const val BOOL_IS_FROM_NAVIGATION_DRAWER_EXTRA_KEY =
"BOOL_IS_FROM_NAVIGATION_DRAWER_EXTRA_KEY"
const val BOOL_IS_ADMINISTRATOR_CONTROLS_SELECTED_KEY =
"BOOL_IS_ADMINISTRATOR_CONTROLS_SELECTED_KEY"
const val INT_LAST_CHECKED_ITEM_KEY =
"INT_LAST_CHECKED_ITEM_KEY"

/**
* This function is responsible for displaying content in DialogFragment.
*
* @return [ExitProfileDialogFragment]: DialogFragment
*/
fun newInstance(isFromNavigationDrawer: Boolean): ExitProfileDialogFragment {
fun newInstance(
isFromNavigationDrawer: Boolean,
isAdministratorControlsSelected: Boolean,
lastCheckedItemId: Int
): ExitProfileDialogFragment {
val exitProfileDialogFragment = ExitProfileDialogFragment()
val args = Bundle()
args.putBoolean(BOOL_IS_FROM_NAVIGATION_DRAWER_EXTRA_KEY, isFromNavigationDrawer)
args.putBoolean(BOOL_IS_ADMINISTRATOR_CONTROLS_SELECTED_KEY, isAdministratorControlsSelected)
args.putInt(INT_LAST_CHECKED_ITEM_KEY, lastCheckedItemId)
exitProfileDialogFragment.arguments = args
return exitProfileDialogFragment
}
Expand All @@ -43,6 +53,15 @@ class ExitProfileDialogFragment : DialogFragment() {
false
)

val isAdminSelected = args.getBoolean(
BOOL_IS_ADMINISTRATOR_CONTROLS_SELECTED_KEY,
false
)

val lastCheckedItemId = args.getInt(
INT_LAST_CHECKED_ITEM_KEY
)

if (isFromNavigationDrawer) {
exitProfileDialogInterface =
parentFragment as ExitProfileDialogInterface
Expand All @@ -53,7 +72,11 @@ class ExitProfileDialogFragment : DialogFragment() {
.setMessage(R.string.home_activity_back_dialog_message)
.setNegativeButton(R.string.home_activity_back_dialog_cancel) { dialog, _ ->
if (isFromNavigationDrawer) {
exitProfileDialogInterface.markHomeMenuCloseDrawer()
exitProfileDialogInterface.markLastCheckedItemCloseDrawer(
anandwana001 marked this conversation as resolved.
Show resolved Hide resolved
lastCheckedItemId,
isAdminSelected
)
exitProfileDialogInterface.unmarkSwitchProfileItemCloseDrawer()
}
dialog.dismiss()
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,6 @@ package org.oppia.app.drawer

/** Interface to handle option selection in [ExitProfileDialogFragment]. */
interface ExitProfileDialogInterface {
fun markHomeMenuCloseDrawer()
fun markLastCheckedItemCloseDrawer(lastCheckedItemId: Int, isAdminSelected: Boolean)
fun unmarkSwitchProfileItemCloseDrawer()
anandwana001 marked this conversation as resolved.
Show resolved Hide resolved
}
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,14 @@ class NavigationDrawerFragment :
navigationDrawerFragmentPresenter.openProfileProgress(profileId)
}

override fun markHomeMenuCloseDrawer() {
navigationDrawerFragmentPresenter.markHomeMenuCloseDrawer()
override fun markLastCheckedItemCloseDrawer(lastCheckedItemId: Int, isAdminSelected: Boolean) {
navigationDrawerFragmentPresenter.markLastCheckedItemCloseDrawer(
lastCheckedItemId,
isAdminSelected
)
}

override fun unmarkSwitchProfileItemCloseDrawer() {
navigationDrawerFragmentPresenter.unmarkSwitchProfileItemCloseDrawer()
}
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package org.oppia.app.drawer

import android.util.Log
import android.view.LayoutInflater
import android.view.MenuItem
import android.view.View
Expand Down Expand Up @@ -57,6 +58,7 @@ class NavigationDrawerFragmentPresenter @Inject constructor(
private lateinit var profileId: ProfileId
private var previousMenuItemId: Int? = null
private var internalProfileId: Int = -1
private var lastCheckedItem: MenuItem? = null

fun handleCreateView(inflater: LayoutInflater, container: ViewGroup?): View? {
binding = DrawerFragmentBinding.inflate(inflater, container, /* attachToRoot= */ false)
Expand Down Expand Up @@ -193,7 +195,6 @@ class NavigationDrawerFragmentPresenter @Inject constructor(
}

private fun openActivityByMenuItemId(menuItemId: Int) {
getFooterViewModel().isAdministratorControlsSelected.set(false)
if (previousMenuItemId != menuItemId) {
when (NavigationDrawerItem.valueFromNavId(menuItemId)) {
NavigationDrawerItem.HOME -> {
Expand Down Expand Up @@ -233,13 +234,20 @@ class NavigationDrawerFragmentPresenter @Inject constructor(
drawerLayout.closeDrawers()
}
NavigationDrawerItem.SWITCH_PROFILE -> {
val isAdminSelected = getFooterViewModel().isAdministratorControlsSelected.get() ?: false
lastCheckedItem = binding.fragmentDrawerNavView.checkedItem
val id: Int = lastCheckedItem?.itemId ?: -1
val previousFragment =
fragment.childFragmentManager.findFragmentByTag(TAG_SWITCH_PROFILE_DIALOG)
if (previousFragment != null) {
fragment.childFragmentManager.beginTransaction().remove(previousFragment).commitNow()
}
val dialogFragment = ExitProfileDialogFragment
.newInstance(isFromNavigationDrawer = true)
.newInstance(
isFromNavigationDrawer = true,
isAdministratorControlsSelected = isAdminSelected,
lastCheckedItemId = id
)
dialogFragment.showNow(fragment.childFragmentManager, TAG_SWITCH_PROFILE_DIALOG)
}
}
Expand All @@ -257,12 +265,32 @@ class NavigationDrawerFragmentPresenter @Inject constructor(
)
}

fun markHomeMenuCloseDrawer() {
fun markLastCheckedItemCloseDrawer(lastCheckedItemId: Int, isAdminSelected: Boolean) {
if (isAdminSelected) {
getFooterViewModel().isAdministratorControlsSelected.set(true)
} else {
if (lastCheckedItemId != -1) {
binding.fragmentDrawerNavView.menu.getItem(
when (lastCheckedItemId) {
NavigationDrawerItem.HOME.value -> 0
NavigationDrawerItem.OPTIONS.value -> 1
NavigationDrawerItem.HELP.value -> 2
NavigationDrawerItem.DOWNLOADS.value -> 3
NavigationDrawerItem.SWITCH_PROFILE.value -> 4
else -> 0
}
).isChecked = true
}
}
drawerLayout.closeDrawers()
}

fun unmarkSwitchProfileItemCloseDrawer() {
Log.d("final", "unmarkSwitchProfileItemCloseDrawer: unmark done")
binding.fragmentDrawerNavView.menu.getItem(
NavigationDrawerItem.HOME.ordinal
NavigationDrawerItem.SWITCH_PROFILE.ordinal
).isChecked =
true
drawerLayout.closeDrawers()
false
}

/**
Expand Down Expand Up @@ -348,6 +376,9 @@ class NavigationDrawerFragmentPresenter @Inject constructor(
R.string.drawer_close_content_description
) {
override fun onDrawerOpened(drawerView: View) {
binding.fragmentDrawerNavView.menu.getItem(
NavigationDrawerItem.SWITCH_PROFILE.ordinal
).isChecked = false
super.onDrawerOpened(drawerView)
fragment.activity!!.invalidateOptionsMenu()
StatusBarColor.statusBarColorUpdate(
Expand Down
6 changes: 5 additions & 1 deletion app/src/main/java/org/oppia/app/home/HomeActivity.kt
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,11 @@ class HomeActivity : InjectableAppCompatActivity(), RouteToTopicListener {
supportFragmentManager.beginTransaction().remove(previousFragment).commitNow()
}
val dialogFragment = ExitProfileDialogFragment
.newInstance(isFromNavigationDrawer = false)
.newInstance(
isFromNavigationDrawer = false,
isAdministratorControlsSelected = false,
lastCheckedItemId = -1
)
dialogFragment.showNow(supportFragmentManager, TAG_SWITCH_PROFILE_DIALOG)
}
}