From e3d34a9737a3a00f9656cd54a8f98dc4f2340d8b Mon Sep 17 00:00:00 2001 From: tibbi Date: Mon, 11 Mar 2019 23:42:03 +0100 Subject: [PATCH] adding an option to switch between notification/email reminders --- app/build.gradle | 2 +- .../calendar/pro/activities/EventActivity.kt | 90 +++++++++++++++++-- app/src/main/res/layout/activity_event.xml | 57 +++++++++++- 3 files changed, 139 insertions(+), 10 deletions(-) diff --git a/app/build.gradle b/app/build.gradle index 24cf745ac..6cfcb9b71 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -57,7 +57,7 @@ android { } dependencies { - implementation 'com.simplemobiletools:commons:5.10.8' + implementation 'com.simplemobiletools:commons:5.10.9' implementation 'joda-time:joda-time:2.10.1' implementation 'androidx.multidex:multidex:2.0.1' diff --git a/app/src/main/kotlin/com/simplemobiletools/calendar/pro/activities/EventActivity.kt b/app/src/main/kotlin/com/simplemobiletools/calendar/pro/activities/EventActivity.kt index d85dd9d3b..8d70f9b56 100644 --- a/app/src/main/kotlin/com/simplemobiletools/calendar/pro/activities/EventActivity.kt +++ b/app/src/main/kotlin/com/simplemobiletools/calendar/pro/activities/EventActivity.kt @@ -23,6 +23,7 @@ import com.simplemobiletools.commons.dialogs.RadioGroupDialog import com.simplemobiletools.commons.extensions.* import com.simplemobiletools.commons.helpers.* import com.simplemobiletools.commons.models.RadioItem +import com.simplemobiletools.commons.views.MyTextView import kotlinx.android.synthetic.main.activity_event.* import org.joda.time.DateTime import java.util.* @@ -45,6 +46,9 @@ class EventActivity : SimpleActivity() { private var mReminder1Minutes = 0 private var mReminder2Minutes = 0 private var mReminder3Minutes = 0 + private var mReminder1Type = REMINDER_NOTIFICATION + private var mReminder2Type = REMINDER_NOTIFICATION + private var mReminder3Type = REMINDER_NOTIFICATION private var mRepeatInterval = 0 private var mRepeatLimit = 0L private var mRepeatRule = 0 @@ -146,10 +150,32 @@ class EventActivity : SimpleActivity() { event_reminder_2.setOnClickListener { showReminder2Dialog() } event_reminder_3.setOnClickListener { showReminder3Dialog() } + event_reminder_1_type.setOnClickListener { + showReminderTypePicker(mReminder1Type) { + mReminder1Type = it + updateReminderTypeText(event_reminder_1_type, mReminder1Type) + } + } + + event_reminder_2_type.setOnClickListener { + showReminderTypePicker(mReminder2Type) { + mReminder2Type = it + updateReminderTypeText(event_reminder_2_type, mReminder2Type) + } + } + + event_reminder_3_type.setOnClickListener { + showReminderTypePicker(mReminder3Type) { + mReminder3Type = it + updateReminderTypeText(event_reminder_3_type, mReminder3Type) + } + } + event_type_holder.setOnClickListener { showEventTypeDialog() } - if (mEvent.flags and FLAG_ALL_DAY != 0) + if (mEvent.flags and FLAG_ALL_DAY != 0) { event_all_day.toggle() + } updateTextColors(event_scrollview) updateIconColors() @@ -253,6 +279,9 @@ class EventActivity : SimpleActivity() { mReminder1Minutes = mEvent.reminder1Minutes mReminder2Minutes = mEvent.reminder2Minutes mReminder3Minutes = mEvent.reminder3Minutes + mReminder1Type = mEvent.reminder1Type + mReminder2Type = mEvent.reminder2Type + mReminder3Type = mEvent.reminder3Type mRepeatInterval = mEvent.repeatInterval mRepeatLimit = mEvent.repeatLimit mRepeatRule = mEvent.repeatRule @@ -558,10 +587,15 @@ class EventActivity : SimpleActivity() { updateReminder1Text() updateReminder2Text() updateReminder3Text() + updateReminderTypeTexts() } private fun updateReminder1Text() { event_reminder_1.text = getFormattedMinutes(mReminder1Minutes) + event_reminder_1_type.apply { + beVisibleIf(mReminder1Minutes != REMINDER_OFF) + text = getString(R.string.notification) + } } private fun updateReminder2Text() { @@ -575,6 +609,11 @@ class EventActivity : SimpleActivity() { alpha = 1f } } + + event_reminder_2_type.apply { + beVisibleIf(mReminder2Minutes != REMINDER_OFF) + text = getString(R.string.notification) + } } private fun updateReminder3Text() { @@ -588,6 +627,32 @@ class EventActivity : SimpleActivity() { alpha = 1f } } + + event_reminder_3_type.apply { + beVisibleIf(mReminder3Minutes != REMINDER_OFF) + text = getString(R.string.notification) + } + } + + private fun showReminderTypePicker(currentValue: Int, callback: (Int) -> Unit) { + val items = arrayListOf( + RadioItem(REMINDER_NOTIFICATION, getString(R.string.notification)), + RadioItem(REMINDER_EMAIL, getString(R.string.email)) + ) + RadioGroupDialog(this, items, currentValue) { + callback(it as Int) + } + } + + private fun updateReminderTypeTexts() { + updateReminderTypeText(event_reminder_1_type, mReminder1Type) + updateReminderTypeText(event_reminder_2_type, mReminder2Type) + updateReminderTypeText(event_reminder_3_type, mReminder3Type) + } + + private fun updateReminderTypeText(view: MyTextView, type: Int) { + val text = getString(if (type == REMINDER_NOTIFICATION) R.string.notification else R.string.email) + view.text = text } private fun updateRepetitionText() { @@ -765,10 +830,22 @@ class EventActivity : SimpleActivity() { "$CALDAV-$mEventCalendarId" } - val reminders = sortedSetOf(mReminder1Minutes, mReminder2Minutes, mReminder3Minutes).filter { it != REMINDER_OFF } - val reminder1 = reminders.getOrElse(0) { REMINDER_OFF } - val reminder2 = reminders.getOrElse(1) { REMINDER_OFF } - val reminder3 = reminders.getOrElse(2) { REMINDER_OFF } + val reminders = LinkedHashMap().apply { + put(mReminder1Minutes, mReminder1Type) + put(mReminder2Minutes, mReminder2Type) + put(mReminder3Minutes, mReminder3Type) + } + + val sortedReminders = reminders.toSortedMap().filter { it.key != REMINDER_OFF } + val keys = sortedReminders.keys.toList() + val reminder1 = keys.getOrElse(0) { REMINDER_OFF } + val reminder2 = keys.getOrElse(1) { REMINDER_OFF } + val reminder3 = keys.getOrElse(2) { REMINDER_OFF } + + val types = sortedReminders.values.toList() + mReminder1Type = types.getOrElse(0) { REMINDER_NOTIFICATION } + mReminder2Type = types.getOrElse(1) { REMINDER_NOTIFICATION } + mReminder3Type = types.getOrElse(2) { REMINDER_NOTIFICATION } config.apply { if (usePreviousEventReminders) { @@ -786,6 +863,9 @@ class EventActivity : SimpleActivity() { reminder1Minutes = reminder1 reminder2Minutes = reminder2 reminder3Minutes = reminder3 + reminder1Type = mReminder1Type + reminder2Type = mReminder2Type + reminder3Type = mReminder3Type repeatInterval = mRepeatInterval importId = newImportId flags = mEvent.flags.addBitIf(event_all_day.isChecked, FLAG_ALL_DAY) diff --git a/app/src/main/res/layout/activity_event.xml b/app/src/main/res/layout/activity_event.xml index eddd5199a..7180b4dd9 100644 --- a/app/src/main/res/layout/activity_event.xml +++ b/app/src/main/res/layout/activity_event.xml @@ -187,11 +187,27 @@ android:layout_height="wrap_content" android:layout_below="@+id/event_date_time_divider" android:layout_marginStart="@dimen/small_margin" + android:layout_toStartOf="@+id/event_reminder_1_type" android:layout_toEndOf="@+id/event_reminder_image" android:background="?attr/selectableItemBackground" + android:ellipsize="end" + android:lines="1" android:paddingTop="@dimen/activity_margin" android:paddingBottom="@dimen/activity_margin" - android:textSize="@dimen/day_text_size"/> + android:textSize="@dimen/day_text_size" + tools:text="@string/add_another_reminder"/> + + + android:visibility="gone" + tools:text="@string/add_another_reminder"/> + + + android:visibility="gone" + tools:text="@string/add_another_reminder"/> + + + android:textSize="@dimen/day_text_size" + tools:text="@string/no_repetition"/>