mirror of
https://github.com/SimpleMobileTools/Simple-Calendar.git
synced 2025-06-05 21:59:17 +02:00
rewrite ManageEventTypes to the new adapter style
This commit is contained in:
@@ -34,7 +34,7 @@ class ManageEventTypesActivity : SimpleActivity(), DeleteEventTypesListener {
|
|||||||
dbHelper.getEventTypes {
|
dbHelper.getEventTypes {
|
||||||
runOnUiThread {
|
runOnUiThread {
|
||||||
manage_event_types_list.adapter = EventTypeAdapter(this, it, this) {
|
manage_event_types_list.adapter = EventTypeAdapter(this, it, this) {
|
||||||
showEventTypeDialog(it)
|
showEventTypeDialog(it as EventType)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -18,7 +18,7 @@ import kotlinx.android.synthetic.main.event_item_day_view.view.*
|
|||||||
class DayEventsAdapter(activity: SimpleActivity, val events: List<Event>, val listener: DeleteEventsListener?, itemClick: (Any) -> Unit) :
|
class DayEventsAdapter(activity: SimpleActivity, val events: List<Event>, val listener: DeleteEventsListener?, itemClick: (Any) -> Unit) :
|
||||||
MyAdapter(activity, itemClick) {
|
MyAdapter(activity, itemClick) {
|
||||||
|
|
||||||
private var allDayString = activity.resources.getString(R.string.all_day)
|
private var allDayString = resources.getString(R.string.all_day)
|
||||||
private var replaceDescriptionWithLocation = config.replaceDescription
|
private var replaceDescriptionWithLocation = config.replaceDescription
|
||||||
|
|
||||||
override fun getActionMenuId() = R.menu.cab_day
|
override fun getActionMenuId() = R.menu.cab_day
|
||||||
@@ -34,33 +34,6 @@ class DayEventsAdapter(activity: SimpleActivity, val events: List<Event>, val li
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun shareEvents() {
|
|
||||||
val eventIds = ArrayList<Int>(selectedPositions.size)
|
|
||||||
selectedPositions.forEach {
|
|
||||||
eventIds.add(events[it].id)
|
|
||||||
}
|
|
||||||
activity.shareEvents(eventIds.distinct())
|
|
||||||
finishActMode()
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun askConfirmDelete() {
|
|
||||||
val eventIds = ArrayList<Int>(selectedPositions.size)
|
|
||||||
val timestamps = ArrayList<Int>(selectedPositions.size)
|
|
||||||
selectedPositions.forEach {
|
|
||||||
eventIds.add(events[it].id)
|
|
||||||
timestamps.add(events[it].startTS)
|
|
||||||
}
|
|
||||||
|
|
||||||
DeleteEventDialog(activity, eventIds) {
|
|
||||||
if (it) {
|
|
||||||
listener?.deleteItems(eventIds)
|
|
||||||
} else {
|
|
||||||
listener?.addEventRepeatException(eventIds, timestamps)
|
|
||||||
}
|
|
||||||
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 createViewHolder(view)
|
return createViewHolder(view)
|
||||||
@@ -109,4 +82,31 @@ class DayEventsAdapter(activity: SimpleActivity, val events: List<Event>, val li
|
|||||||
event_item_description.setTextColor(textColor)
|
event_item_description.setTextColor(textColor)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun shareEvents() {
|
||||||
|
val eventIds = ArrayList<Int>(selectedPositions.size)
|
||||||
|
selectedPositions.forEach {
|
||||||
|
eventIds.add(events[it].id)
|
||||||
|
}
|
||||||
|
activity.shareEvents(eventIds.distinct())
|
||||||
|
finishActMode()
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun askConfirmDelete() {
|
||||||
|
val eventIds = ArrayList<Int>(selectedPositions.size)
|
||||||
|
val timestamps = ArrayList<Int>(selectedPositions.size)
|
||||||
|
selectedPositions.forEach {
|
||||||
|
eventIds.add(events[it].id)
|
||||||
|
timestamps.add(events[it].startTS)
|
||||||
|
}
|
||||||
|
|
||||||
|
DeleteEventDialog(activity, eventIds) {
|
||||||
|
if (it) {
|
||||||
|
listener?.deleteItems(eventIds)
|
||||||
|
} else {
|
||||||
|
listener?.addEventRepeatException(eventIds, timestamps)
|
||||||
|
}
|
||||||
|
finishActMode()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,14 +1,10 @@
|
|||||||
package com.simplemobiletools.calendar.adapters
|
package com.simplemobiletools.calendar.adapters
|
||||||
|
|
||||||
import android.support.v7.view.ActionMode
|
import android.view.LayoutInflater
|
||||||
import android.support.v7.widget.RecyclerView
|
import android.view.View
|
||||||
import android.view.*
|
import android.view.ViewGroup
|
||||||
import com.bignerdranch.android.multiselector.ModalMultiSelectorCallback
|
|
||||||
import com.bignerdranch.android.multiselector.MultiSelector
|
|
||||||
import com.bignerdranch.android.multiselector.SwappingHolder
|
|
||||||
import com.simplemobiletools.calendar.R
|
import com.simplemobiletools.calendar.R
|
||||||
import com.simplemobiletools.calendar.activities.SimpleActivity
|
import com.simplemobiletools.calendar.activities.SimpleActivity
|
||||||
import com.simplemobiletools.calendar.extensions.config
|
|
||||||
import com.simplemobiletools.calendar.extensions.dbHelper
|
import com.simplemobiletools.calendar.extensions.dbHelper
|
||||||
import com.simplemobiletools.calendar.interfaces.DeleteEventTypesListener
|
import com.simplemobiletools.calendar.interfaces.DeleteEventTypesListener
|
||||||
import com.simplemobiletools.calendar.models.EventType
|
import com.simplemobiletools.calendar.models.EventType
|
||||||
@@ -18,63 +14,48 @@ import com.simplemobiletools.commons.models.RadioItem
|
|||||||
import kotlinx.android.synthetic.main.item_event_type.view.*
|
import kotlinx.android.synthetic.main.item_event_type.view.*
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
class EventTypeAdapter(val activity: SimpleActivity, val mItems: List<EventType>, val listener: DeleteEventTypesListener?, val itemClick: (EventType) -> Unit) :
|
class EventTypeAdapter(activity: SimpleActivity, val eventTypes: List<EventType>, val listener: DeleteEventTypesListener?, itemClick: (Any) -> Unit) :
|
||||||
RecyclerView.Adapter<EventTypeAdapter.ViewHolder>() {
|
MyAdapter(activity, itemClick) {
|
||||||
val multiSelector = MultiSelector()
|
|
||||||
val views = ArrayList<View>()
|
|
||||||
|
|
||||||
companion object {
|
override fun getActionMenuId() = R.menu.cab_event_type
|
||||||
var actMode: ActionMode? = null
|
|
||||||
val markedItems = HashSet<Int>()
|
|
||||||
var textColor = 0
|
|
||||||
|
|
||||||
fun toggleItemSelection(itemView: View, select: Boolean, pos: Int = -1) {
|
override fun markItemSelection(select: Boolean, pos: Int) {
|
||||||
itemView.event_item_frame.isSelected = select
|
itemViews[pos].event_item_frame.isSelected = select
|
||||||
if (pos == -1) {
|
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (select) {
|
override fun actionItemPressed(id: Int) {
|
||||||
markedItems.add(pos)
|
when (id) {
|
||||||
} else {
|
|
||||||
markedItems.remove(pos)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
init {
|
|
||||||
textColor = activity.config.textColor
|
|
||||||
}
|
|
||||||
|
|
||||||
private val multiSelectorMode = object : ModalMultiSelectorCallback(multiSelector) {
|
|
||||||
override fun onActionItemClicked(mode: ActionMode, item: MenuItem): Boolean {
|
|
||||||
when (item.itemId) {
|
|
||||||
R.id.cab_delete -> askConfirmDelete()
|
R.id.cab_delete -> askConfirmDelete()
|
||||||
else -> return false
|
|
||||||
}
|
}
|
||||||
return true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onCreateActionMode(actionMode: ActionMode?, menu: Menu?): Boolean {
|
override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): MyAdapter.ViewHolder {
|
||||||
super.onCreateActionMode(actionMode, menu)
|
val view = LayoutInflater.from(parent?.context).inflate(R.layout.item_event_type, parent, false)
|
||||||
actMode = actionMode
|
return createViewHolder(view)
|
||||||
activity.menuInflater.inflate(R.menu.cab_event_type, menu)
|
|
||||||
return true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onPrepareActionMode(actionMode: ActionMode?, menu: Menu) = true
|
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
|
||||||
|
val eventType = eventTypes[position]
|
||||||
|
val view = holder.bindView(eventType) {
|
||||||
|
setupView(it, eventType)
|
||||||
|
}
|
||||||
|
itemViews.put(position, view)
|
||||||
|
toggleItemSelection(selectedPositions.contains(position), position)
|
||||||
|
}
|
||||||
|
|
||||||
override fun onDestroyActionMode(actionMode: ActionMode?) {
|
override fun getItemCount() = eventTypes.size
|
||||||
super.onDestroyActionMode(actionMode)
|
|
||||||
views.forEach { toggleItemSelection(it, false) }
|
private fun setupView(view: View, eventType: EventType) {
|
||||||
markedItems.clear()
|
view.apply {
|
||||||
|
event_type_title.text = eventType.getDisplayTitle()
|
||||||
|
event_type_color.setBackgroundWithStroke(eventType.color, config.backgroundColor)
|
||||||
|
event_type_title.setTextColor(textColor)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun askConfirmDelete() {
|
private fun askConfirmDelete() {
|
||||||
val selections = multiSelector.selectedPositions
|
val eventTypes = ArrayList<EventType>(selectedPositions.size)
|
||||||
val eventTypes = ArrayList<EventType>(selections.size)
|
selectedPositions.forEach { eventTypes.add(this.eventTypes[it]) }
|
||||||
selections.forEach { eventTypes.add(mItems[it]) }
|
|
||||||
|
|
||||||
if (activity.dbHelper.doEventTypesContainEvent(eventTypes)) {
|
if (activity.dbHelper.doEventTypesContainEvent(eventTypes)) {
|
||||||
val MOVE_EVENTS = 0
|
val MOVE_EVENTS = 0
|
||||||
@@ -85,7 +66,7 @@ class EventTypeAdapter(val activity: SimpleActivity, val mItems: List<EventType>
|
|||||||
add(RadioItem(DELETE_EVENTS, res.getString(R.string.remove_affected_events)))
|
add(RadioItem(DELETE_EVENTS, res.getString(R.string.remove_affected_events)))
|
||||||
}
|
}
|
||||||
RadioGroupDialog(activity, items, -1) {
|
RadioGroupDialog(activity, items, -1) {
|
||||||
actMode?.finish()
|
finishActMode()
|
||||||
deleteEventTypes(it == DELETE_EVENTS, eventTypes)
|
deleteEventTypes(it == DELETE_EVENTS, eventTypes)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@@ -95,62 +76,6 @@ class EventTypeAdapter(val activity: SimpleActivity, val mItems: List<EventType>
|
|||||||
|
|
||||||
private fun deleteEventTypes(deleteEvents: Boolean, eventTypes: ArrayList<EventType>) {
|
private fun deleteEventTypes(deleteEvents: Boolean, eventTypes: ArrayList<EventType>) {
|
||||||
listener?.deleteEventTypes(eventTypes, deleteEvents)
|
listener?.deleteEventTypes(eventTypes, deleteEvents)
|
||||||
actMode?.finish()
|
finishActMode()
|
||||||
}
|
|
||||||
|
|
||||||
override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): ViewHolder {
|
|
||||||
val view = LayoutInflater.from(parent?.context).inflate(R.layout.item_event_type, parent, false)
|
|
||||||
return ViewHolder(activity, view, itemClick)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
|
|
||||||
views.add(holder.bindView(multiSelectorMode, multiSelector, mItems[position], position))
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getItemCount() = mItems.size
|
|
||||||
|
|
||||||
class ViewHolder(val activity: SimpleActivity, view: View, val itemClick: (EventType) -> (Unit)) : SwappingHolder(view, MultiSelector()) {
|
|
||||||
fun bindView(multiSelectorCallback: ModalMultiSelectorCallback, multiSelector: MultiSelector, eventType: EventType, pos: Int): View {
|
|
||||||
|
|
||||||
itemView.apply {
|
|
||||||
event_type_title.text = eventType.getDisplayTitle()
|
|
||||||
event_type_color.setBackgroundWithStroke(eventType.color, activity.config.backgroundColor)
|
|
||||||
toggleItemSelection(this, markedItems.contains(pos), pos)
|
|
||||||
|
|
||||||
event_type_title.setTextColor(textColor)
|
|
||||||
|
|
||||||
setOnClickListener { viewClicked(multiSelector, eventType, pos) }
|
|
||||||
setOnLongClickListener {
|
|
||||||
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
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun viewClicked(multiSelector: MultiSelector, eventType: EventType, pos: Int) {
|
|
||||||
if (multiSelector.isSelectable) {
|
|
||||||
val isSelected = multiSelector.selectedPositions.contains(layoutPosition)
|
|
||||||
multiSelector.setSelected(this, !isSelected)
|
|
||||||
toggleItemSelection(itemView, !isSelected, pos)
|
|
||||||
|
|
||||||
val selectedCnt = multiSelector.selectedPositions.size
|
|
||||||
if (selectedCnt == 0) {
|
|
||||||
actMode?.finish()
|
|
||||||
} else {
|
|
||||||
actMode?.title = selectedCnt.toString()
|
|
||||||
}
|
|
||||||
actMode?.invalidate()
|
|
||||||
} else {
|
|
||||||
itemClick(eventType)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,10 +16,11 @@ import java.util.*
|
|||||||
|
|
||||||
abstract class MyAdapter(val activity: SimpleActivity, val itemClick: (Any) -> Unit) : RecyclerView.Adapter<MyAdapter.ViewHolder>() {
|
abstract class MyAdapter(val activity: SimpleActivity, val itemClick: (Any) -> Unit) : RecyclerView.Adapter<MyAdapter.ViewHolder>() {
|
||||||
protected val config = activity.config
|
protected val config = activity.config
|
||||||
|
protected val resources = activity.resources
|
||||||
protected var actMode: ActionMode? = null
|
protected var actMode: ActionMode? = null
|
||||||
protected var primaryColor = config.primaryColor
|
protected var primaryColor = config.primaryColor
|
||||||
protected var textColor = config.textColor
|
protected var textColor = config.textColor
|
||||||
protected var itemViews = SparseArray<View>()
|
protected val itemViews = SparseArray<View>()
|
||||||
protected val selectedPositions = HashSet<Int>()
|
protected val selectedPositions = HashSet<Int>()
|
||||||
protected val multiSelector = MultiSelector()
|
protected val multiSelector = MultiSelector()
|
||||||
|
|
||||||
|
@@ -25,7 +25,8 @@
|
|||||||
android:inputType="textCapSentences"
|
android:inputType="textCapSentences"
|
||||||
android:maxLength="80"
|
android:maxLength="80"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:textCursorDrawable="@null"/>
|
android:textCursorDrawable="@null"
|
||||||
|
android:textSize="@dimen/normal_text_size"/>
|
||||||
|
|
||||||
<com.simplemobiletools.commons.views.MyTextView
|
<com.simplemobiletools.commons.views.MyTextView
|
||||||
android:id="@+id/type_color_label"
|
android:id="@+id/type_color_label"
|
||||||
|
Reference in New Issue
Block a user