update DayEventsAdapter code style

This commit is contained in:
tibbi
2017-11-13 14:08:35 +01:00
parent b9a2fd4f41
commit c3a770ab43
4 changed files with 79 additions and 64 deletions

View File

@ -110,7 +110,7 @@ class DayActivity : SimpleActivity(), NavigationListener, ViewPager.OnPageChange
override fun onPageSelected(position: Int) { override fun onPageSelected(position: Int) {
mPagerPos = position mPagerPos = position
(view_pager.adapter as MyDayPagerAdapter).destroyMultiselector() (view_pager.adapter as MyDayPagerAdapter).destroyMultiselector(position)
} }
override fun goLeft() { override fun goLeft() {

View File

@ -3,6 +3,7 @@ package com.simplemobiletools.calendar.adapters
import android.graphics.PorterDuff import android.graphics.PorterDuff
import android.support.v7.view.ActionMode import android.support.v7.view.ActionMode
import android.support.v7.widget.RecyclerView import android.support.v7.widget.RecyclerView
import android.util.SparseArray
import android.view.* import android.view.*
import com.bignerdranch.android.multiselector.ModalMultiSelectorCallback import com.bignerdranch.android.multiselector.ModalMultiSelectorCallback
import com.bignerdranch.android.multiselector.MultiSelector import com.bignerdranch.android.multiselector.MultiSelector
@ -17,39 +18,51 @@ import com.simplemobiletools.calendar.interfaces.DeleteEventsListener
import com.simplemobiletools.calendar.models.Event import com.simplemobiletools.calendar.models.Event
import com.simplemobiletools.commons.extensions.beInvisible import com.simplemobiletools.commons.extensions.beInvisible
import com.simplemobiletools.commons.extensions.beInvisibleIf import com.simplemobiletools.commons.extensions.beInvisibleIf
import com.simplemobiletools.commons.interfaces.MyAdapterListener
import kotlinx.android.synthetic.main.event_item_day_view.view.* import kotlinx.android.synthetic.main.event_item_day_view.view.*
import java.util.* import java.util.*
class DayEventsAdapter(val activity: SimpleActivity, val mItems: List<Event>, val listener: DeleteEventsListener?, val itemClick: (Event) -> Unit) : class DayEventsAdapter(val activity: SimpleActivity, val events: List<Event>, val listener: DeleteEventsListener?, val itemClick: (Event) -> Unit) :
RecyclerView.Adapter<DayEventsAdapter.ViewHolder>() { RecyclerView.Adapter<DayEventsAdapter.ViewHolder>() {
val multiSelector = MultiSelector() private val config = activity.config
val views = ArrayList<View>() private var actMode: ActionMode? = null
private var textColor = config.textColor
private val multiSelector = MultiSelector()
private var itemViews = SparseArray<View>()
private val selectedPositions = HashSet<Int>()
private var allDayString = activity.resources.getString(R.string.all_day)
private var replaceDescriptionWithLocation = config.replaceDescription
companion object { fun toggleItemSelection(select: Boolean, pos: Int) {
var actMode: ActionMode? = null if (select) {
val markedItems = HashSet<Int>() if (itemViews[pos] != null) {
var textColor = 0 selectedPositions.add(pos)
var allDayString = ""
var replaceDescriptionWithLocation = false
fun toggleItemSelection(itemView: View, select: Boolean, pos: Int = -1) {
itemView.event_item_frame.isSelected = select
if (pos == -1) {
return
}
if (select) {
markedItems.add(pos)
} else {
markedItems.remove(pos)
} }
} else {
selectedPositions.remove(pos)
} }
itemViews[pos].event_item_frame.isSelected = select
if (selectedPositions.isEmpty()) {
finishActMode()
return
}
updateTitle(selectedPositions.size)
} }
init { private fun updateTitle(cnt: Int) {
textColor = activity.config.textColor actMode?.title = "$cnt / ${events.size}"
allDayString = activity.resources.getString(R.string.all_day) actMode?.invalidate()
replaceDescriptionWithLocation = activity.config.replaceDescription }
private val adapterListener = object : MyAdapterListener {
override fun toggleItemSelectionAdapter(select: Boolean, position: Int) {
toggleItemSelection(select, position)
}
override fun getSelectedPositions() = selectedPositions
} }
private val multiSelectorMode = object : ModalMultiSelectorCallback(multiSelector) { private val multiSelectorMode = object : ModalMultiSelectorCallback(multiSelector) {
@ -73,19 +86,26 @@ class DayEventsAdapter(val activity: SimpleActivity, val mItems: List<Event>, va
override fun onDestroyActionMode(actionMode: ActionMode?) { override fun onDestroyActionMode(actionMode: ActionMode?) {
super.onDestroyActionMode(actionMode) super.onDestroyActionMode(actionMode)
views.forEach { toggleItemSelection(it, false) } selectedPositions.forEach {
markedItems.clear() itemViews[it].event_item_frame.isSelected = false
}
selectedPositions.clear()
actMode = null
} }
} }
fun finishActMode() {
actMode?.finish()
}
private fun shareEvents() { private fun shareEvents() {
val selections = multiSelector.selectedPositions val selections = multiSelector.selectedPositions
val eventIds = ArrayList<Int>(selections.size) val eventIds = ArrayList<Int>(selections.size)
selections.forEach { selections.forEach {
eventIds.add(mItems[it].id) eventIds.add(events[it].id)
} }
activity.shareEvents(eventIds.distinct()) activity.shareEvents(eventIds.distinct())
actMode?.finish() finishActMode()
} }
private fun askConfirmDelete() { private fun askConfirmDelete() {
@ -93,8 +113,8 @@ class DayEventsAdapter(val activity: SimpleActivity, val mItems: List<Event>, va
val eventIds = ArrayList<Int>(selections.size) val eventIds = ArrayList<Int>(selections.size)
val timestamps = ArrayList<Int>(selections.size) val timestamps = ArrayList<Int>(selections.size)
selections.forEach { selections.forEach {
eventIds.add(mItems[it].id) eventIds.add(events[it].id)
timestamps.add(mItems[it].startTS) timestamps.add(events[it].startTS)
} }
DeleteEventDialog(activity, eventIds) { DeleteEventDialog(activity, eventIds) {
@ -103,23 +123,26 @@ class DayEventsAdapter(val activity: SimpleActivity, val mItems: List<Event>, va
} else { } else {
listener?.addEventRepeatException(eventIds, timestamps) listener?.addEventRepeatException(eventIds, timestamps)
} }
actMode?.finish() finishActMode()
} }
} }
override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): ViewHolder { override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): ViewHolder {
val view = LayoutInflater.from(parent?.context).inflate(R.layout.event_item_day_view, parent, false) val view = LayoutInflater.from(parent?.context).inflate(R.layout.event_item_day_view, parent, false)
return ViewHolder(activity, view, itemClick) return ViewHolder(view, adapterListener, activity, multiSelectorMode, multiSelector, itemClick)
} }
override fun onBindViewHolder(holder: ViewHolder, position: Int) { override fun onBindViewHolder(holder: ViewHolder, position: Int) {
views.add(holder.bindView(multiSelectorMode, multiSelector, mItems[position], position)) val event = events[position]
itemViews.put(position, holder.bindView(event, textColor, replaceDescriptionWithLocation, allDayString))
toggleItemSelection(selectedPositions.contains(position), position)
} }
override fun getItemCount() = mItems.size override fun getItemCount() = events.size
class ViewHolder(val activity: SimpleActivity, view: View, val itemClick: (Event) -> (Unit)) : SwappingHolder(view, MultiSelector()) { class ViewHolder(view: View, val adapterListener: MyAdapterListener, val activity: SimpleActivity, val multiSelectorCallback: ModalMultiSelectorCallback,
fun bindView(multiSelectorCallback: ModalMultiSelectorCallback, multiSelector: MultiSelector, event: Event, pos: Int): View { val multiSelector: MultiSelector, val itemClick: (Event) -> (Unit)) : SwappingHolder(view, MultiSelector()) {
fun bindView(event: Event, textColor: Int, replaceDescriptionWithLocation: Boolean, allDayString: String): View {
itemView.apply { itemView.apply {
event_item_title.text = event.title event_item_title.text = event.title
event_item_description.text = if (replaceDescriptionWithLocation) event.location else event.description event_item_description.text = if (replaceDescriptionWithLocation) event.location else event.description
@ -127,8 +150,6 @@ class DayEventsAdapter(val activity: SimpleActivity, val mItems: List<Event>, va
event_item_end.beInvisibleIf(event.startTS == event.endTS) event_item_end.beInvisibleIf(event.startTS == event.endTS)
event_item_color.setColorFilter(event.color, PorterDuff.Mode.SRC_IN) event_item_color.setColorFilter(event.color, PorterDuff.Mode.SRC_IN)
toggleItemSelection(this, markedItems.contains(pos), pos)
if (event.startTS != event.endTS) { if (event.startTS != event.endTS) {
val startCode = Formatter.getDayCodeFromTS(event.startTS) val startCode = Formatter.getDayCodeFromTS(event.startTS)
val endCode = Formatter.getDayCodeFromTS(event.endTS) val endCode = Formatter.getDayCodeFromTS(event.endTS)
@ -152,38 +173,27 @@ class DayEventsAdapter(val activity: SimpleActivity, val mItems: List<Event>, va
event_item_title.setTextColor(textColor) event_item_title.setTextColor(textColor)
event_item_description.setTextColor(textColor) event_item_description.setTextColor(textColor)
setOnClickListener { viewClicked(multiSelector, event, pos) } setOnClickListener { viewClicked(event) }
setOnLongClickListener { setOnLongClickListener { viewLongClicked(); true }
if (!multiSelector.isSelectable) {
activity.startSupportActionMode(multiSelectorCallback)
multiSelector.setSelected(this@ViewHolder, true)
actMode?.title = multiSelector.selectedPositions.size.toString()
toggleItemSelection(itemView, true, pos)
actMode?.invalidate()
}
true
}
} }
return itemView return itemView
} }
private fun viewClicked(multiSelector: MultiSelector, event: Event, pos: Int) { private fun viewClicked(event: Event) {
if (multiSelector.isSelectable) { if (multiSelector.isSelectable) {
val isSelected = multiSelector.selectedPositions.contains(layoutPosition) val isSelected = adapterListener.getSelectedPositions().contains(adapterPosition)
multiSelector.setSelected(this, !isSelected) adapterListener.toggleItemSelectionAdapter(!isSelected, adapterPosition)
toggleItemSelection(itemView, !isSelected, pos)
val selectedCnt = multiSelector.selectedPositions.size
if (selectedCnt == 0) {
actMode?.finish()
} else {
actMode?.title = selectedCnt.toString()
}
actMode?.invalidate()
} else { } else {
itemClick(event) itemClick(event)
} }
} }
private fun viewLongClicked() {
if (!multiSelector.isSelectable) {
activity.startSupportActionMode(multiSelectorCallback)
adapterListener.toggleItemSelectionAdapter(true, adapterPosition)
}
}
} }
} }

View File

@ -34,7 +34,9 @@ class MyDayPagerAdapter(fm: FragmentManager, private val mCodes: List<String>, p
} }
} }
fun destroyMultiselector() { fun destroyMultiselector(pos: Int) {
DayEventsAdapter.actMode?.finish() for (i in -1..1) {
mFragments[pos + i]?.getDayEventsAdapter()?.finishActMode()
}
} }
} }

View File

@ -82,6 +82,8 @@ class DayFragment : Fragment(), DBHelper.EventUpdateListener, DeleteEventsListen
} }
} }
fun getDayEventsAdapter() = mHolder.day_events?.adapter as? DayEventsAdapter
private fun pickDay() { private fun pickDay() {
activity!!.setTheme(context!!.getAppropriateTheme()) activity!!.setTheme(context!!.getAppropriateTheme())
val view = layoutInflater.inflate(R.layout.date_picker, null) val view = layoutInflater.inflate(R.layout.date_picker, null)
@ -140,6 +142,7 @@ class DayFragment : Fragment(), DBHelper.EventUpdateListener, DeleteEventsListen
val eventsAdapter = DayEventsAdapter(activity as SimpleActivity, events, this) { val eventsAdapter = DayEventsAdapter(activity as SimpleActivity, events, this) {
editEvent(it) editEvent(it)
} }
mHolder.day_events.adapter = eventsAdapter mHolder.day_events.adapter = eventsAdapter
DividerItemDecoration(context, DividerItemDecoration.VERTICAL).apply { DividerItemDecoration(context, DividerItemDecoration.VERTICAL).apply {
setDrawable(context!!.resources.getDrawable(R.drawable.divider)) setDrawable(context!!.resources.getDrawable(R.drawable.divider))