mirror of
https://github.com/SimpleMobileTools/Simple-Calendar.git
synced 2025-06-05 21:59:17 +02:00
update DayEventsAdapter code style
This commit is contained in:
@ -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() {
|
||||||
|
@ -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)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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))
|
||||||
|
Reference in New Issue
Block a user