implement custom snooze for notifications

pull/367/merge
Luboš Luňák 8 years ago
parent 52c4282601
commit 43e802fb8e

@ -91,6 +91,7 @@
android:name="android.support.PARENT_ACTIVITY"
android:value=".activities.habits.list.ListHabitsActivity"/>
</activity>
<activity android:name=".notifications.SnoozeDelayActivity"></activity>
<receiver
android:name=".widgets.CheckmarkWidgetProvider"

@ -0,0 +1,85 @@
package org.isoron.uhabits.notifications;
import android.content.*;
import android.os.*;
import android.support.v4.app.*;
import android.text.format.*;
import android.util.*;
import com.android.datetimepicker.time.*;
import org.isoron.uhabits.core.utils.DateUtils;
import org.isoron.uhabits.receivers.*;
import java.util.*;
import static org.isoron.uhabits.core.utils.DateUtils.applyTimezone;
public class SnoozeDelayActivity extends FragmentActivity implements
TimePickerDialog.OnTimeSetListener {
public static final String ACTION_ASK_SNOOZE = "org.isoron.uhabits.ACTION_ASK_SNOOZE";
private static final String TAG = "SnoozeDelayActivity";
@Override
protected void onCreate(Bundle bundle)
{
super.onCreate(bundle);
Intent intent = getIntent();
try
{
switch (intent.getAction())
{
case ACTION_ASK_SNOOZE:
AskSnooze();
break;
}
}
catch (RuntimeException e)
{
Log.e(TAG, "could not process intent", e);
}
}
private void AskSnooze()
{
final Calendar calendar = Calendar.getInstance();
int hour = calendar.get(Calendar.HOUR_OF_DAY);
int minute = calendar.get(Calendar.MINUTE);
TimePickerDialog dialog;
dialog = TimePickerDialog.newInstance(this,
hour, minute, DateFormat.is24HourFormat(this));
dialog.show(getSupportFragmentManager(),"timePicker");
}
@Override
public void onTimeSet(RadialPickerLayout view, int hourOfDay, int minute)
{
Calendar calendar = DateUtils.getStartOfTodayCalendar();
calendar.set(Calendar.HOUR_OF_DAY, hourOfDay);
calendar.set(Calendar.MINUTE, minute);
calendar.set(Calendar.SECOND, 0);
Long time = calendar.getTimeInMillis();
if (DateUtils.getLocalTime() > time)
time += DateUtils.DAY_LENGTH;
time = applyTimezone(time);
Intent intent = new Intent( ReminderReceiver.ACTION_SNOOZE_REMINDER_SET, getIntent().getData(),
this, ReminderReceiver.class );
intent.putExtra("reminderTime", time);
sendBroadcast(intent);
finish();
}
@Override
public void onTimeCleared(RadialPickerLayout view)
{
Intent intent = new Intent( ReminderReceiver.ACTION_DISMISS_REMINDER, getIntent().getData(),
this, ReminderReceiver.class );
sendBroadcast(intent);
finish();
}
}

@ -19,12 +19,15 @@
package org.isoron.uhabits.receivers;
import android.content.*;
import android.net.*;
import android.support.annotation.*;
import org.isoron.uhabits.core.models.*;
import org.isoron.uhabits.core.preferences.*;
import org.isoron.uhabits.core.reminders.*;
import org.isoron.uhabits.core.ui.*;
import org.isoron.uhabits.notifications.*;
import javax.inject.*;
@ -65,13 +68,32 @@ public class ReminderController
reminderScheduler.scheduleAll();
}
public void onSnooze(@NonNull Habit habit)
public void onSnooze(@NonNull Habit habit, final Context context)
{
long snoozeInterval = preferences.getSnoozeInterval();
if (snoozeInterval < 0)
{
context.sendBroadcast( new Intent(Intent.ACTION_CLOSE_SYSTEM_DIALOGS));
Intent intent = new Intent( SnoozeDelayActivity.ACTION_ASK_SNOOZE, Uri.parse( habit.getUriString()),
context, SnoozeDelayActivity.class );
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
return;
}
snoozeNotificationAddDelay(habit, snoozeInterval);
}
public void snoozeNotificationAddDelay(@NonNull Habit habit, long snoozeInterval)
{
long now = applyTimezone(getLocalTime());
long reminderTime = now + snoozeInterval * 60 * 1000;
snoozeNotificationSetReminderTime(habit, reminderTime);
}
public void snoozeNotificationSetReminderTime(@NonNull Habit habit, long reminderTime)
{
reminderScheduler.schedule(habit, reminderTime);
notificationTray.cancel(habit);
}

@ -46,6 +46,9 @@ public class ReminderReceiver extends BroadcastReceiver
public static final String ACTION_SNOOZE_REMINDER =
"org.isoron.uhabits.ACTION_SNOOZE_REMINDER";
public static final String ACTION_SNOOZE_REMINDER_SET =
"org.isoron.uhabits.ACTION_SNOOZE_REMINDER_SET";
private static final String TAG = "ReminderReceiver";
@Override
@ -90,7 +93,12 @@ public class ReminderReceiver extends BroadcastReceiver
case ACTION_SNOOZE_REMINDER:
if (habit == null) return;
reminderController.onSnooze(habit);
reminderController.onSnooze(habit,context);
break;
case ACTION_SNOOZE_REMINDER_SET:
if (habit == null) return;
reminderController.snoozeNotificationSetReminderTime(habit, reminderTime);
break;
case Intent.ACTION_BOOT_COMPLETED:

@ -35,6 +35,7 @@
<item>@string/interval_4_hour</item>
<item>@string/interval_8_hour</item>
<item>@string/interval_24_hour</item>
<item>@string/interval_always_ask</item>
</string-array>
<string-array name="snooze_interval_values" translatable="false">
@ -45,6 +46,7 @@
<item>240</item>
<item>480</item>
<item>1440</item>
<item>-1</item>
</string-array>
<string-array name="frequencyQuickSelect" translatable="false">

@ -83,6 +83,7 @@
<string name="interval_4_hour">4 hours</string>
<string name="interval_8_hour">8 hours</string>
<string name="interval_24_hour">24 hours</string>
<string name="interval_always_ask">Always ask</string>
<string name="pref_toggle_title">Toggle with short press</string>
<string name="pref_toggle_description">Put checkmarks with a single tap instead of press-and-hold. More convenient, but might cause accidental toggles.</string>
<string name="pref_snooze_interval_title">Snooze interval on reminders</string>

@ -70,7 +70,7 @@ public class ReminderControllerTest extends BaseAndroidJVMTest
DateUtils.setFixedLocalTime(now);
when(preferences.getSnoozeInterval()).thenReturn(15L);
controller.onSnooze(habit);
controller.onSnooze(habit,null);
verify(reminderScheduler).schedule(habit, nowTz + 900000);
verify(notificationTray).cancel(habit);

Loading…
Cancel
Save