Skip to content

Instantly share code, notes, and snippets.

@Younes-Charfaoui
Created September 14, 2021 16:25
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save Younes-Charfaoui/b291e66fd073a5ebe03775d55009a887 to your computer and use it in GitHub Desktop.
Save Younes-Charfaoui/b291e66fd073a5ebe03775d55009a887 to your computer and use it in GitHub Desktop.
#if (${PACKAGE_NAME} && ${PACKAGE_NAME} != "")package ${PACKAGE_NAME}#end
import androidx.recyclerview.widget.RecyclerView
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.view.View.OnClickListener
import androidx.recyclerview.widget.DiffUtil
import androidx.recyclerview.widget.ListAdapter
#parse("File Header.java")
class ${NAME}(private val interaction: Interaction? = null) : ListAdapter<${Model_Class}, ${NAME}.${ViewHolder_Class}>(${Model_Class}DC()) {
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int) = ${ViewHolder_Class}(
LayoutInflater.from(parent.context)
.inflate(R.layout.${Item_Layout_ID}, parent, false)
)
override fun onBindViewHolder(holder: ${ViewHolder_Class}, position: Int) = holder.bind(getItem(position))
inner class ${ViewHolder_Class}(itemView: View) : RecyclerView.ViewHolder(itemView){
fun bind(item: ${Model_Class}) {
// TODO: Bind the data with View
}
}
interface Interaction {
}
private class ${Model_Class}DC : DiffUtil.ItemCallback<${Model_Class}>() {
override fun areItemsTheSame(oldItem: ${Model_Class}, newItem: ${Model_Class}): Boolean {
TODO( "not implemented")
}
override fun areContentsTheSame(oldItem: ${Model_Class}, newItem: ${Model_Class}): Boolean {
TODO("not implemented")
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment