Skip to content

Commit

Permalink
highlight selected card
Browse files Browse the repository at this point in the history
This commit ensures that the selected card should be highlighted on large screens only. By default first card should be highlighted
  • Loading branch information
SanjaySargam committed Jul 25, 2024
1 parent aa3e409 commit 241a1f9
Showing 1 changed file with 17 additions and 10 deletions.
27 changes: 17 additions & 10 deletions AnkiDroid/src/main/java/com/ichi2/anki/CardBrowser.kt
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,13 @@ open class CardBrowser :
ChangeManager.Subscriber,
ExportDialogsFactoryProvider {

/**
* Provides an instance of NoteEditorLauncher for adding a note
*/
@get:VisibleForTesting
val addNoteLauncher: NoteEditorLauncher
get() = createAddNoteLauncher(viewModel)

/**
* Provides an instance of NoteEditorLauncher for editing a note
*/
Expand Down Expand Up @@ -657,6 +664,8 @@ open class CardBrowser :
// load up the card selected on the list
val clickedCardId = viewModel.queryCardIdAtPosition(position)
saveScrollingState(position)
// set selected position
cardsAdapter.selectedPosition = position
openNoteEditorForCard(clickedCardId)
}
}
Expand Down Expand Up @@ -1339,13 +1348,6 @@ open class CardBrowser :
showDialogFragment(dialog)
}

/**
* Provides an instance of NoteEditorLauncher for adding a note
*/
@get:VisibleForTesting
val addNoteLauncher: NoteEditorLauncher
get() = createAddNoteLauncher(viewModel)

private fun addNoteFromCardBrowser() {
if (fragmented) {
loadNoteEditorFragmentIfFragmented(addNoteLauncher)
Expand Down Expand Up @@ -1849,6 +1851,7 @@ open class CardBrowser :
) : BaseAdapter() {
private var originalTextSize = -1.0f
private val inflater: LayoutInflater
var selectedPosition: Int = 0
override fun getView(position: Int, convertView: View?, parent: ViewGroup): View {
// Get the main container view if it doesn't already exist, and call bindView
val v: View
Expand Down Expand Up @@ -1876,8 +1879,10 @@ open class CardBrowser :
setFont(column as TextView) // set font for column
column.text = card.getColumnHeaderText(fromKeys[i]) // set text for column
}
// check whether the view is selected
val isHighLight = position == selectedPosition
// set card's background color
val backgroundColor: Int = card.getBackgroundColor(this@CardBrowser)
val backgroundColor: Int = card.getBackgroundColor(this@CardBrowser, isHighLight)
v.setBackgroundColor(backgroundColor)
// setup checkbox to change color in multi-select mode
val checkBox = v.findViewById<CheckBox>(R.id.card_checkbox)
Expand Down Expand Up @@ -2059,12 +2064,14 @@ open class CardBrowser :
* @return index into TypedArray specifying the background color
*/
@ColorInt
fun getBackgroundColor(context: Context): Int {
fun getBackgroundColor(context: Context, isHighlight: Boolean): Int {
val flagColor = Flag.fromCode(card.userFlag()).browserColorRes
if (flagColor != null) {
return context.getColor(flagColor)
}
val colorAttr = if (isMarked(col, card.note(col))) {
val colorAttr = if (isHighlight) {
R.attr.currentDeckBackgroundColor
} else if (isMarked(col, card.note(col))) {
R.attr.markedColor
} else if (card.queue == Consts.QUEUE_TYPE_SUSPENDED) {
R.attr.suspendedColor
Expand Down

0 comments on commit 241a1f9

Please sign in to comment.