diff --git a/res/values/arrays.xml b/res/values/arrays.xml index 8307a7e1b5eb2dfd865bba453f65b143be959314..ffc1653282c224aaf39d69a48ee8fc1cf57c1b00 100644 --- a/res/values/arrays.xml +++ b/res/values/arrays.xml @@ -154,6 +154,7 @@ + "-1" "5" "10" "15" diff --git a/res/values/strings.xml b/res/values/strings.xml index afac62488e7ccb2e277dbf43eda1c2c841b6e512..b2c2e583c472faf7ca390ed0f930251678e8e960 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -38,6 +38,7 @@ (No title) + None 1 minute diff --git a/src/com/android/calendar/alerts/AlertReceiver.java b/src/com/android/calendar/alerts/AlertReceiver.java index 797795209e0a16be319db672d61a0eae3091b8f9..2abe59200d84a9009676587a529b8b83dd708446 100644 --- a/src/com/android/calendar/alerts/AlertReceiver.java +++ b/src/com/android/calendar/alerts/AlertReceiver.java @@ -48,6 +48,8 @@ import android.text.style.URLSpan; import android.util.Log; import android.widget.Toast; +import androidx.annotation.Nullable; + import com.android.calendar.DynamicTheme; import com.android.calendar.Utils; import com.android.calendar.alerts.AlertService.NotificationWrapper; @@ -185,8 +187,16 @@ public class AlertReceiver extends BroadcastReceiver { return PendingIntent.getService(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT); } + // if default snooze minute < 0, means the snooze option is disable + // in this case return null as intent + @Nullable private static PendingIntent createSnoozeIntent(Context context, long eventId, long startMillis, long endMillis, int notificationId) { + + if (Utils.getDefaultSnoozeDelayMs(context) < 0L) { + return null; + } + Intent intent = new Intent(); intent.putExtra(AlertUtils.EVENT_ID_KEY, eventId); intent.putExtra(AlertUtils.EVENT_START_KEY, startMillis); diff --git a/src/com/android/calendar/alerts/SnoozeAlarmsService.java b/src/com/android/calendar/alerts/SnoozeAlarmsService.java index f0a7ff556b11dc9010cd24668352ce0c273c460b..70351e9337e58428ee2481cee7c549f6b4ad7ed9 100644 --- a/src/com/android/calendar/alerts/SnoozeAlarmsService.java +++ b/src/com/android/calendar/alerts/SnoozeAlarmsService.java @@ -32,6 +32,7 @@ import androidx.core.content.ContextCompat; import android.util.Log; import com.android.calendar.Utils; +import com.android.calendar.settings.GeneralPreferences; /** * Service for asynchronously marking a fired alarm as dismissed and scheduling @@ -92,6 +93,10 @@ public class SnoozeAlarmsService extends IntentService { resolver.update(uri, dismissValues, selection, null); // Add a new alarm + if (snoozeDelay < 0) { + snoozeDelay = GeneralPreferences.SNOOZE_DELAY_DEFAULT_TIME * 60L * 1000L; + } + long alarmTime = System.currentTimeMillis() + snoozeDelay; ContentValues values = AlertUtils.makeContentValues(eventId, eventStart, eventEnd, alarmTime, 0); diff --git a/src/com/android/calendar/alerts/SnoozeDelayActivity.java b/src/com/android/calendar/alerts/SnoozeDelayActivity.java index 41e9d2c323d045af9eb98c56609070fffa2703e3..dd228c4e71f69494fdd6f9de492fced38e3a8d56 100644 --- a/src/com/android/calendar/alerts/SnoozeDelayActivity.java +++ b/src/com/android/calendar/alerts/SnoozeDelayActivity.java @@ -24,6 +24,7 @@ import android.content.Intent; import android.widget.TimePicker; import com.android.calendar.Utils; +import com.android.calendar.settings.GeneralPreferences; import ws.xsoh.etar.R; @@ -55,6 +56,11 @@ public class SnoozeDelayActivity extends Activity implements if (id == DIALOG_DELAY) { TimePickerDialog tpd = (TimePickerDialog) d; int delayMinutes = (int) (Utils.getDefaultSnoozeDelayMs(this) / (60L * 1000L)); + + if (delayMinutes < 0) { + delayMinutes = GeneralPreferences.SNOOZE_DELAY_DEFAULT_TIME; + } + int hours = delayMinutes / 60; int minutes = delayMinutes % 60; diff --git a/src/com/android/calendar/event/EventViewUtils.java b/src/com/android/calendar/event/EventViewUtils.java index 8a63f3b0ae369afb585139a7648346f3cfef4268..8d580593bf83badb0e512d44c85438971cf5f2a8 100644 --- a/src/com/android/calendar/event/EventViewUtils.java +++ b/src/com/android/calendar/event/EventViewUtils.java @@ -45,8 +45,14 @@ public class EventViewUtils { // if the given minutes is 63, then this returns the string "63 minutes". // As another example, if the given minutes is 120, then this returns // "2 hours". + // if minute is < 0, returns `None` public static String constructReminderLabel(Context context, int minutes, boolean abbrev) { Resources resources = context.getResources(); + + if (minutes < 0) { + return resources.getString(R.string.no_snooze_label); + } + int value, resId; if (minutes % 60 != 0) { diff --git a/src/com/android/calendar/settings/GeneralPreferences.kt b/src/com/android/calendar/settings/GeneralPreferences.kt index 125c1365507c8bdbe7b1eea82ae1c582c76afcd3..3543ed47edae9e0fe5ea60384bc3132f6f9dd373 100644 --- a/src/com/android/calendar/settings/GeneralPreferences.kt +++ b/src/com/android/calendar/settings/GeneralPreferences.kt @@ -62,6 +62,7 @@ class GeneralPreferences : PreferenceFragmentCompat(), private lateinit var homeTzPref: Preference private lateinit var popupPref: CheckBoxPreference private lateinit var snoozeDelayPref: ListPreference + private lateinit var useDefaultCustomSnoozeDelayPref: Preference private lateinit var defaultReminderPref: ListPreference private lateinit var copyDbPref: Preference private lateinit var skipRemindersPref: ListPreference @@ -105,6 +106,7 @@ class GeneralPreferences : PreferenceFragmentCompat(), homeTzPref = preferenceScreen.findPreference(KEY_HOME_TZ)!! popupPref = preferenceScreen.findPreference(KEY_ALERTS_POPUP)!! snoozeDelayPref = preferenceScreen.findPreference(KEY_DEFAULT_SNOOZE_DELAY)!! + useDefaultCustomSnoozeDelayPref = preferenceScreen.findPreference(KEY_USE_CUSTOM_SNOOZE_DELAY)!! defaultReminderPref = preferenceScreen.findPreference(KEY_DEFAULT_REMINDER)!! copyDbPref = preferenceScreen.findPreference(KEY_OTHER_COPY_DB)!! skipRemindersPref = preferenceScreen.findPreference(KEY_OTHER_REMINDERS_RESPONDED)!! @@ -136,6 +138,7 @@ class GeneralPreferences : PreferenceFragmentCompat(), } buildSnoozeDelayEntries() + handleUseCustomSnoozeDelayVisibility() defaultEventDurationPref.summary = defaultEventDurationPref.entry themePref.summary = themePref.entry weekStartPref.summary = weekStartPref.entry @@ -191,6 +194,10 @@ class GeneralPreferences : PreferenceFragmentCompat(), } } + private fun handleUseCustomSnoozeDelayVisibility() { + useDefaultCustomSnoozeDelayPref.isEnabled = Integer.parseInt(snoozeDelayPref.value) >= 0 + } + private fun showColorPickerDialog() { val colorPickerDialog = ColorPickerDialogX() val selectedColorName = Utils.getSharedPreference(activity, KEY_COLOR_PREF, "teal") @@ -343,6 +350,7 @@ class GeneralPreferences : PreferenceFragmentCompat(), snoozeDelayPref -> { snoozeDelayPref.value = newValue as String snoozeDelayPref.summary = snoozeDelayPref.entry + handleUseCustomSnoozeDelayVisibility() } defaultStartPref -> { val i = defaultStartPref.findIndexOfValue(newValue as String)