Skip to content

Commit

Permalink
For mozilla-mobile#3213: Fix multi-select bookmarks on return to frag…
Browse files Browse the repository at this point in the history
…ment
  • Loading branch information
colintheshots committed Jun 13, 2019
1 parent 5eb2bc6 commit e542ba9
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,19 +34,19 @@ class BookmarkAdapter(val emptyView: View, val actionEmitter: Observer<BookmarkA

private var tree: List<BookmarkNode> = listOf()
private var mode: BookmarkState.Mode = BookmarkState.Mode.Normal
var selected = setOf<BookmarkNode>()
val selected: Set<BookmarkNode>
get() = (mode as? BookmarkState.Mode.Selecting)?.selectedItems ?: setOf()
private var isFirstRun = true

lateinit var job: Job

fun updateData(tree: BookmarkNode?, mode: BookmarkState.Mode) {
this.tree = tree?.children?.filterNotNull() ?: listOf()
this.tree = tree?.children ?: listOf()
isFirstRun = if (isFirstRun) false else {
emptyView.visibility = if (this.tree.isEmpty()) View.VISIBLE else View.GONE
false
}
this.mode = mode
this.selected = if (mode is BookmarkState.Mode.Selecting) mode.selectedItems else setOf()
notifyDataSetChanged()
}

Expand Down Expand Up @@ -137,9 +137,9 @@ class BookmarkAdapter(val emptyView: View, val actionEmitter: Observer<BookmarkA
val shiftTwoDp = TypedValue.applyDimension(
TypedValue.COMPLEX_UNIT_DIP, TWO_DIGIT_MARGIN, containerView!!.context.resources.displayMetrics
).toInt()
val params = bookmark_title.getLayoutParams() as ViewGroup.MarginLayoutParams
val params = bookmark_title.layoutParams as ViewGroup.MarginLayoutParams
params.topMargin = shiftTwoDp
bookmark_title.setLayoutParams(params)
bookmark_title.layoutParams = params

bookmark_favicon.visibility = View.VISIBLE
bookmark_title.visibility = View.VISIBLE
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ sealed class BookmarkAction : Action {
data class Delete(val item: BookmarkNode) : BookmarkAction()
object BackPressed : BookmarkAction()
object SwitchMode : BookmarkAction()
object DeselectAll : BookmarkAction()
}

sealed class BookmarkChange : Change {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -275,11 +275,10 @@ class BookmarkFragment : Fragment(), CoroutineScope, BackHandler, AccountObserve
}
}
is BookmarkAction.SwitchMode -> {
if ((bookmarkComponent.uiView as BookmarkUIView).mode is BookmarkState.Mode.Normal) {
getManagedEmitter<BookmarkChange>().onNext(BookmarkChange.ClearSelection)
}
activity?.invalidateOptionsMenu()
}
is BookmarkAction.DeselectAll ->
getManagedEmitter<BookmarkChange>().onNext(BookmarkChange.ClearSelection)
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,20 +65,16 @@ class BookmarkUIView(
mode = it.mode
actionEmitter.onNext(BookmarkAction.SwitchMode)
}
bookmarkAdapter.updateData(it.tree, it.mode)
when (val modeCopy = mode) {
when (val modeCopy = it.mode) {
is BookmarkState.Mode.Normal -> setUIForNormalMode(it.tree)
is BookmarkState.Mode.Selecting -> setUIForSelectingMode(modeCopy)
is BookmarkState.Mode.Selecting -> setUIForSelectingMode(it.tree, modeCopy)
}
}

override fun onBackPressed(): Boolean {
return when {
mode is BookmarkState.Mode.Selecting -> {
mode = BookmarkState.Mode.Normal
bookmarkAdapter.updateData(tree, mode)
setUIForNormalMode(tree)
actionEmitter.onNext(BookmarkAction.SwitchMode)
actionEmitter.onNext(BookmarkAction.DeselectAll)
true
}
canGoBack -> {
Expand Down Expand Up @@ -107,8 +103,10 @@ class BookmarkUIView(
}

private fun setUIForSelectingMode(
root: BookmarkNode?,
mode: BookmarkState.Mode.Selecting
) {
bookmarkAdapter.updateData(root, mode)
activity?.title =
context.getString(R.string.bookmarks_multi_select_title, mode.selectedItems.size)
setToolbarColors(
Expand All @@ -118,6 +116,7 @@ class BookmarkUIView(
}

private fun setUIForNormalMode(root: BookmarkNode?) {
bookmarkAdapter.updateData(root, BookmarkState.Mode.Normal)
setTitle(root)
setToolbarColors(
R.attr.primaryText.getColorIntFromAttr(context!!),
Expand Down

0 comments on commit e542ba9

Please sign in to comment.