Pilldroid/app/src/main/java/net/foucry/pilldroid/PillDroidJobService.java

128 lines
4.1 KiB
Java
Raw Normal View History

2016-10-18 16:29:07 +02:00
package net.foucry.pilldroid;
2020-09-11 17:21:01 +02:00
import android.app.NotificationChannel;
import android.app.NotificationManager;
import android.app.PendingIntent;
2016-10-18 16:29:07 +02:00
import android.app.job.JobParameters;
import android.app.job.JobService;
import android.content.Intent;
2020-09-11 17:21:01 +02:00
import android.icu.util.Calendar;
2016-10-18 16:29:07 +02:00
import android.util.Log;
2020-09-11 17:21:01 +02:00
import androidx.core.app.NotificationCompat;
import androidx.core.app.NotificationManagerCompat;
import java.util.List;
2016-10-18 16:29:07 +02:00
/**
* Created by jacques on 17/09/16.
*/
2020-09-11 17:21:01 +02:00
2016-10-18 16:29:07 +02:00
public class PillDroidJobService extends JobService {
2020-09-11 17:21:01 +02:00
private static final String TAG = JobService.class.getName();
private boolean jobCancelled = false;
2020-09-12 19:05:42 +02:00
private String CHANNEL_ID = "PillDroid";
2020-09-11 17:21:01 +02:00
private DBHelper dbHelper = new DBHelper(this);
@Override
public boolean onStartJob(JobParameters params) {
Log.d(TAG, "Job started");
createNotificationChannel();
doBackgroundWork(params);
2020-09-11 17:21:01 +02:00
return true;
}
/**
* Grab sorted list of medicaments
* test dateAlert of the first of the list
* if dateAlert < now
* schedule notification
* @param params JobParameters
2020-09-11 17:21:01 +02:00
*/
private void doBackgroundWork(final JobParameters params) {
2020-09-27 14:17:38 +02:00
Log.d(TAG,"background job");
2020-09-11 17:21:01 +02:00
if (jobCancelled) {
return;
}
2020-09-11 17:21:01 +02:00
List<Medicament> medicaments = dbHelper.getAllDrugs();
2020-09-11 17:21:01 +02:00
Medicament firstMedicament = null;
try {
firstMedicament = medicaments.get(0);
}
catch (Exception e){
Log.e(TAG, e.toString());
e.printStackTrace();
}
2020-09-11 17:21:01 +02:00
if (firstMedicament != null) {
2020-09-22 11:06:01 +02:00
if (firstMedicament.getPrise() != 0) {
scheduleNotification();
2020-09-22 11:06:01 +02:00
}
2020-09-11 17:21:01 +02:00
}
Log.d(TAG, "Job finished");
2020-09-27 14:17:38 +02:00
jobFinished(params, false);
2016-10-18 16:29:07 +02:00
}
2020-09-11 17:21:01 +02:00
2016-10-18 16:29:07 +02:00
@Override
public boolean onStopJob(JobParameters params) {
2020-09-11 17:21:01 +02:00
Log.d(TAG, "Job cancelled before completion");
jobCancelled = true;
return true;
2016-10-18 16:29:07 +02:00
}
2020-09-11 17:21:01 +02:00
/**
* Schedule Notification for the delay
*/
private void scheduleNotification() {
2020-09-27 14:17:38 +02:00
Log.d(TAG, "schedule notification");
2020-09-11 17:21:01 +02:00
createNotificationChannel();
Intent intent = new Intent(this, MedicamentListActivity.class);
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent,0);
2020-09-11 17:21:01 +02:00
NotificationCompat.Builder builder = new NotificationCompat.Builder(this, CHANNEL_ID)
.setSmallIcon(R.drawable.ic_pill)
.setContentTitle(getString(R.string.app_name))
.setContentText(getString(R.string.notification_text))
.setPriority(NotificationCompat.PRIORITY_DEFAULT)
.setContentIntent(pendingIntent)
2020-09-11 17:21:01 +02:00
.setAutoCancel(true);
NotificationManagerCompat notificationManager = NotificationManagerCompat.from(this);
int notificationId = 666;
notificationManager.notify(notificationId, builder.build());
}
2020-08-21 10:34:12 +02:00
2020-09-11 17:21:01 +02:00
/**
* createNotificationChannelid for android API >= 28
*/
private void createNotificationChannel() {
2020-08-21 10:34:12 +02:00
2020-09-11 17:21:01 +02:00
Log.d(TAG, "start create notification channel");
CharSequence name = getString(R.string.channel_name);
String description = getString(R.string.channel_description);
int importance = NotificationManager.IMPORTANCE_DEFAULT;
NotificationChannel channel = new NotificationChannel(CHANNEL_ID, name, importance);
channel.setDescription(description);
// Register the channel with the system; you can't change the importance
// or other notification behaviors after this
NotificationManager notificationManager = getSystemService(NotificationManager.class);
try {
notificationManager.createNotificationChannel(channel);
} catch (Exception e) {
// This will catch any exception, because they are all descended from Exception
Log.e(TAG, e.toString());
//At the level Exception Class handle the error in Exception Table
// Exception Create That Error Object and throw it
//E.g: FileNotFoundException ,etc
e.printStackTrace();
}
}
}