Reputation: 93
I am looking for solution to iterate over all views of my Recycler View Adapter elements to get EditTexts and change inputs.
I use RecyclerView list. Item rows contain EditText. When user clicks a button, I want to clear inputs of all item views, even those not bound yet. How should I do that?
class ScoresAdapter : RecyclerView.Adapter<ScoresViewHolder>() {
private var scores: List<Score> = ArrayList()
private var listener: ScoreItemListener? = null
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ScoresViewHolder {
val view =
LayoutInflater
.from(parent.context)
.inflate(R.layout.score_item, parent, false)
return ScoresViewHolder(view)
}
override fun getItemCount(): Int {
return scores.size
}
override fun onBindViewHolder(holder: ScoresViewHolder, position: Int) {
val score = scores[position]
holder.playerView.text = score.player.email
holder.totalScoreView.text = score.total().toString()
}
fun setItemListener(listener: ScoreItemListener) {
this.listener = listener
}
fun loadScores(scores: ArrayList<Score>) {
this.scores = scores
notifyDataSetChanged()
}
fun clearInputs() {
// for all scores in list remove text from EditText and set ""
}
inner class ScoresViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
var playerView = itemView.findViewById<TextView>(R.id.player)!!
var currentScoreView = itemView.findViewById<EditText>(R.id.current_score)!!
var totalScoreView = itemView.findViewById<TextView>(R.id.total_score)!!
init {
setTextChangedListener(itemView)
}
private fun setTextChangedListener(itemView: View) {
if (listener != null)
currentScoreView.addTextChangedListener(object : TextWatcher {
override fun afterTextChanged(s: Editable?) {
}
override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {
}
override fun onTextChanged(text: CharSequence?, start: Int, before: Int, count: Int) {
listener!!.textChanged(itemView, text!!.toString(), adapterPosition)
}
})
}
}
}
Upvotes: 3
Views: 843
Reputation: 4969
Try with this it might work
override fun onBindViewHolder(holder: ScoresViewHolder, position: Int) {
val score = scores[position]
holder.playerView.text = if(clearEditText) "" else score.player.email
holder.totalScoreView.text = score.total().toString()
holder.currentScoreView.setText("")
}
public void clearInputs() {
notifyDataSetChanged();
}
Upvotes: 0
Reputation: 4371
I understand you might have to save EditText
input as currentScore
in Score
later.
Assuming this and currentScore
as String
.
In java:
public void clearInputs() {
for(Score score: scores) {
score.currentScore = "";
}
notifyDataSetChanged();
}
in Kotlin:
fun clearInputs() {
for (score in scores)
{
score.currentScore = ""
}
notifyDataSetChanged()
}
Upvotes: 0
Reputation: 4074
You can do something like below ::
var clearEditText = false
override fun onBindViewHolder(holder: ScoresViewHolder, position: Int) {
val score = scores[position]
holder.playerView.text = if(clearEditText) "" else score.player.email
holder.totalScoreView.text = score.total().toString()
}
fun clearInputs() {
clearEditText = true
notifyDataSetChanged();
}
Upvotes: 4