mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-01-04 23:37:12 +01:00
Delete PullNotificationAlarmReceiver because it seems no notification bug is finally fixed (Wrong TimeUnit in NotificationPreferenceFragment).
This commit is contained in:
parent
2df26c3faa
commit
24261df3db
@ -347,8 +347,6 @@
|
|||||||
android:name=".Service.SubmitPostService"
|
android:name=".Service.SubmitPostService"
|
||||||
android:enabled="true"
|
android:enabled="true"
|
||||||
android:exported="false" />
|
android:exported="false" />
|
||||||
|
|
||||||
<receiver android:process=":remote" android:name=".PullNotificationAlarmReceiver" />
|
|
||||||
</application>
|
</application>
|
||||||
|
|
||||||
</manifest>
|
</manifest>
|
@ -335,7 +335,6 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (enableNotification) {
|
if (enableNotification) {
|
||||||
//PullNotificationAlarmReceiver.setNotificationAlarm(this, notificationInterval);
|
|
||||||
Constraints constraints = new Constraints.Builder()
|
Constraints constraints = new Constraints.Builder()
|
||||||
.setRequiredNetworkType(NetworkType.CONNECTED)
|
.setRequiredNetworkType(NetworkType.CONNECTED)
|
||||||
.build();
|
.build();
|
||||||
@ -349,7 +348,6 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
|||||||
workManager.enqueueUniquePeriodicWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
workManager.enqueueUniquePeriodicWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
||||||
ExistingPeriodicWorkPolicy.KEEP, pullNotificationRequest);
|
ExistingPeriodicWorkPolicy.KEEP, pullNotificationRequest);
|
||||||
} else {
|
} else {
|
||||||
//PullNotificationAlarmReceiver.cancelAlarm(this);
|
|
||||||
workManager.cancelUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME);
|
workManager.cancelUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -363,7 +361,6 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
|||||||
mKarma = account.getKarma();
|
mKarma = account.getKarma();
|
||||||
|
|
||||||
if (enableNotification) {
|
if (enableNotification) {
|
||||||
//PullNotificationAlarmReceiver.setNotificationAlarm(this, notificationInterval);
|
|
||||||
Constraints constraints = new Constraints.Builder()
|
Constraints constraints = new Constraints.Builder()
|
||||||
.setRequiredNetworkType(NetworkType.CONNECTED)
|
.setRequiredNetworkType(NetworkType.CONNECTED)
|
||||||
.build();
|
.build();
|
||||||
@ -377,7 +374,6 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
|||||||
workManager.enqueueUniquePeriodicWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
workManager.enqueueUniquePeriodicWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
||||||
ExistingPeriodicWorkPolicy.KEEP, pullNotificationRequest);
|
ExistingPeriodicWorkPolicy.KEEP, pullNotificationRequest);
|
||||||
} else {
|
} else {
|
||||||
//PullNotificationAlarmReceiver.cancelAlarm(this);
|
|
||||||
workManager.cancelUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME);
|
workManager.cancelUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -395,7 +391,6 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (enableNotification) {
|
if (enableNotification) {
|
||||||
//PullNotificationAlarmReceiver.setNotificationAlarm(this, notificationInterval);
|
|
||||||
Constraints constraints = new Constraints.Builder()
|
Constraints constraints = new Constraints.Builder()
|
||||||
.setRequiredNetworkType(NetworkType.CONNECTED)
|
.setRequiredNetworkType(NetworkType.CONNECTED)
|
||||||
.build();
|
.build();
|
||||||
@ -409,7 +404,6 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
|||||||
workManager.enqueueUniquePeriodicWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
workManager.enqueueUniquePeriodicWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
||||||
ExistingPeriodicWorkPolicy.KEEP, pullNotificationRequest);
|
ExistingPeriodicWorkPolicy.KEEP, pullNotificationRequest);
|
||||||
} else {
|
} else {
|
||||||
//PullNotificationAlarmReceiver.cancelAlarm(this);
|
|
||||||
workManager.cancelUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME);
|
workManager.cancelUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,6 +197,4 @@ public interface AppComponent {
|
|||||||
void inject(DownloadLocationPreferenceFragment downloadLocationPreferenceFragment);
|
void inject(DownloadLocationPreferenceFragment downloadLocationPreferenceFragment);
|
||||||
|
|
||||||
void inject(SubmitCrosspostActivity submitCrosspostActivity);
|
void inject(SubmitCrosspostActivity submitCrosspostActivity);
|
||||||
|
|
||||||
void inject(PullNotificationAlarmReceiver pullNotificationAlarmReceiver);
|
|
||||||
}
|
}
|
||||||
|
@ -1,106 +0,0 @@
|
|||||||
package ml.docilealligator.infinityforreddit;
|
|
||||||
|
|
||||||
import android.app.AlarmManager;
|
|
||||||
import android.app.PendingIntent;
|
|
||||||
import android.content.BroadcastReceiver;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.graphics.Color;
|
|
||||||
import android.os.PowerManager;
|
|
||||||
import android.util.Log;
|
|
||||||
|
|
||||||
import androidx.core.app.NotificationCompat;
|
|
||||||
import androidx.core.app.NotificationManagerCompat;
|
|
||||||
import androidx.work.Constraints;
|
|
||||||
import androidx.work.ExistingWorkPolicy;
|
|
||||||
import androidx.work.NetworkType;
|
|
||||||
import androidx.work.OneTimeWorkRequest;
|
|
||||||
import androidx.work.WorkManager;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
|
||||||
import javax.inject.Named;
|
|
||||||
|
|
||||||
import ml.docilealligator.infinityforreddit.CustomTheme.CustomThemeWrapper;
|
|
||||||
import ml.docilealligator.infinityforreddit.Utils.NotificationUtils;
|
|
||||||
import retrofit2.Retrofit;
|
|
||||||
|
|
||||||
public class PullNotificationAlarmReceiver extends BroadcastReceiver {
|
|
||||||
|
|
||||||
@Inject
|
|
||||||
@Named("oauth_without_authenticator")
|
|
||||||
Retrofit mOauthWithoutAuthenticatorRetrofit;
|
|
||||||
@Inject
|
|
||||||
@Named("no_oauth")
|
|
||||||
Retrofit mRetrofit;
|
|
||||||
@Inject
|
|
||||||
RedditDataRoomDatabase mRedditDataRoomDatabase;
|
|
||||||
@Inject
|
|
||||||
@Named("default")
|
|
||||||
SharedPreferences mSharedPreferences;
|
|
||||||
@Inject
|
|
||||||
CustomThemeWrapper mCustomThemeWrapper;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onReceive(Context context, Intent receivedIntent) {
|
|
||||||
((Infinity) context.getApplicationContext()).getAppComponent().inject(this);
|
|
||||||
|
|
||||||
PowerManager pm = (PowerManager) context.getSystemService(Context.POWER_SERVICE);
|
|
||||||
PowerManager.WakeLock wl = null;
|
|
||||||
if (pm != null) {
|
|
||||||
wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "ml.docilealligator.infinityforreddit:notification");
|
|
||||||
wl.acquire(2*60*1000L /*2 minutes*/);
|
|
||||||
}
|
|
||||||
|
|
||||||
Log.i("asasdfsdaf", "time: " + System.currentTimeMillis());
|
|
||||||
|
|
||||||
NotificationManagerCompat testNotificationManager = NotificationUtils.getNotificationManager(context);
|
|
||||||
|
|
||||||
NotificationCompat.Builder testSummaryBuilder = NotificationUtils.buildSummaryNotification(context,
|
|
||||||
testNotificationManager, "test",
|
|
||||||
Long.toString(System.currentTimeMillis()),
|
|
||||||
NotificationUtils.CHANNEL_ID_NEW_MESSAGES, NotificationUtils.CHANNEL_NEW_MESSAGES,
|
|
||||||
NotificationUtils.getAccountGroupName("test"), Color.BLACK);
|
|
||||||
testNotificationManager.notify(NotificationUtils.getSummaryIdUnreadMessage(12), testSummaryBuilder.build());
|
|
||||||
|
|
||||||
WorkManager workManager = WorkManager.getInstance(context);
|
|
||||||
|
|
||||||
Constraints constraints = new Constraints.Builder()
|
|
||||||
.setRequiredNetworkType(NetworkType.CONNECTED)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
OneTimeWorkRequest pullNotificationRequest =
|
|
||||||
new OneTimeWorkRequest.Builder(PullNotificationWorker.class)
|
|
||||||
.setConstraints(constraints)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
workManager.enqueueUniqueWork(PullNotificationWorker.UNIQUE_WORKER_NAME,
|
|
||||||
ExistingWorkPolicy.KEEP, pullNotificationRequest);
|
|
||||||
|
|
||||||
if (wl != null) {
|
|
||||||
wl.release();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void setNotificationAlarm(Context context, long notificationInterval) {
|
|
||||||
AlarmManager am =(AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
|
|
||||||
if (am != null) {
|
|
||||||
Intent intent = new Intent(context, PullNotificationAlarmReceiver.class);
|
|
||||||
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, NotificationUtils.PULL_NOTIFICATION_ALARM_RECEIVER_REQUEST_CODE, intent, 0);
|
|
||||||
if ((notificationInterval == 15 || notificationInterval == 30)) {
|
|
||||||
am.setInexactRepeating(AlarmManager.ELAPSED_REALTIME, 60 * 1000, 1000 * 60 * notificationInterval, pendingIntent); // Millisec * Second * Minute
|
|
||||||
} else {
|
|
||||||
am.setInexactRepeating(AlarmManager.ELAPSED_REALTIME, 60 * 1000, 1000 * 60 * 60 * notificationInterval, pendingIntent); // Millisec * Second * Minute
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void cancelAlarm(Context context) {
|
|
||||||
AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
|
|
||||||
if (alarmManager != null) {
|
|
||||||
Intent intent = new Intent(context, AlarmManager.class);
|
|
||||||
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, NotificationUtils.PULL_NOTIFICATION_ALARM_RECEIVER_REQUEST_CODE, intent, 0);
|
|
||||||
alarmManager.cancel(pendingIntent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user