mirror of
https://github.com/immich-app/immich.git
synced 2025-01-27 22:22:45 +01:00
ask user to disable battery optimizations when turning on background backup (#554)
* ask user to disable battery optimizations when turning on background backup * remove obsolete texts/translations * add button link to dontkillmyapp
This commit is contained in:
parent
5172242f88
commit
75d2d82d05
8 changed files with 58 additions and 33 deletions
mobile
android/app/src/main/kotlin/com/example/mobile
assets/i18n
lib/modules/backup
background_service
providers
views
|
@ -69,26 +69,8 @@ class BackgroundServicePlugin : FlutterPlugin, MethodChannel.MethodCallHandler {
|
||||||
"isEnabled" -> {
|
"isEnabled" -> {
|
||||||
result.success(BackupWorker.isEnabled(ctx))
|
result.success(BackupWorker.isEnabled(ctx))
|
||||||
}
|
}
|
||||||
"disableBatteryOptimizations" -> {
|
"isIgnoringBatteryOptimizations" -> {
|
||||||
if(!BackupWorker.isIgnoringBatteryOptimizations(ctx)) {
|
result.success(BackupWorker.isIgnoringBatteryOptimizations(ctx))
|
||||||
val args = call.arguments<ArrayList<*>>()!!
|
|
||||||
val text = args.get(0) as String
|
|
||||||
Toast.makeText(ctx, text, Toast.LENGTH_LONG).show()
|
|
||||||
val intent = Intent(Settings.ACTION_IGNORE_BATTERY_OPTIMIZATION_SETTINGS)
|
|
||||||
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
|
|
||||||
intent.setData(Uri.parse("package:" + ctx.getPackageName()))
|
|
||||||
try {
|
|
||||||
ctx.startActivity(intent)
|
|
||||||
} catch(e: Exception) {
|
|
||||||
intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS)
|
|
||||||
try {
|
|
||||||
ctx.startActivity(intent)
|
|
||||||
} catch (e2: Exception) {
|
|
||||||
return result.success(false)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
result.success(true)
|
|
||||||
}
|
}
|
||||||
else -> result.notImplemented()
|
else -> result.notImplemented()
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
"backup_album_selection_page_total_assets": "Total unique assets",
|
"backup_album_selection_page_total_assets": "Total unique assets",
|
||||||
"backup_all": "All",
|
"backup_all": "All",
|
||||||
"backup_background_service_default_notification": "Checking for new assets…",
|
"backup_background_service_default_notification": "Checking for new assets…",
|
||||||
"backup_background_service_disable_battery_optimizations": "Please disable battery optimization for Immich to enable background backup",
|
|
||||||
"backup_background_service_upload_failure_notification": "Failed to upload {}",
|
"backup_background_service_upload_failure_notification": "Failed to upload {}",
|
||||||
"backup_background_service_in_progress_notification": "Backing up your assets…",
|
"backup_background_service_in_progress_notification": "Backing up your assets…",
|
||||||
"backup_background_service_current_upload_notification": "Uploading {}",
|
"backup_background_service_current_upload_notification": "Uploading {}",
|
||||||
|
@ -36,6 +35,10 @@
|
||||||
"backup_controller_page_background_turn_on": "Turn on background service",
|
"backup_controller_page_background_turn_on": "Turn on background service",
|
||||||
"backup_controller_page_background_turn_off": "Turn off background service",
|
"backup_controller_page_background_turn_off": "Turn off background service",
|
||||||
"backup_controller_page_background_configure_error": "Failed to configure the background service",
|
"backup_controller_page_background_configure_error": "Failed to configure the background service",
|
||||||
|
"backup_controller_page_background_battery_info_title": "Battery optimizations",
|
||||||
|
"backup_controller_page_background_battery_info_message": "For the best background backup experience, please disable any battery optimizations restricting background activity for Immich.\n\nSince this is device-specific, please lookup the required information for your device manufacturer.",
|
||||||
|
"backup_controller_page_background_battery_info_link": "Show me how",
|
||||||
|
"backup_controller_page_background_battery_info_ok": "OK",
|
||||||
"backup_controller_page_cancel": "Cancel",
|
"backup_controller_page_cancel": "Cancel",
|
||||||
"backup_controller_page_created": "Created on: {}",
|
"backup_controller_page_created": "Created on: {}",
|
||||||
"backup_controller_page_desc_backup": "Turn on backup to automatically upload new assets to the server.",
|
"backup_controller_page_desc_backup": "Turn on backup to automatically upload new assets to the server.",
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
"backup_album_selection_page_total_assets": "총 미디어파일 수",
|
"backup_album_selection_page_total_assets": "총 미디어파일 수",
|
||||||
"backup_all": "모두",
|
"backup_all": "모두",
|
||||||
"backup_background_service_default_notification": "새 미디어파일 확인중...",
|
"backup_background_service_default_notification": "새 미디어파일 확인중...",
|
||||||
"backup_background_service_disable_battery_optimizations": "백그라운드 백업을 활성화하려면 Immich에 대한 배터리최적화를 비활성화 해야합니다.",
|
|
||||||
"backup_background_service_upload_failure_notification": "{} 업로드 실패",
|
"backup_background_service_upload_failure_notification": "{} 업로드 실패",
|
||||||
"backup_background_service_in_progress_notification": "미디어파일 백업 중...",
|
"backup_background_service_in_progress_notification": "미디어파일 백업 중...",
|
||||||
"backup_background_service_current_upload_notification": "{} 업로드 중",
|
"backup_background_service_current_upload_notification": "{} 업로드 중",
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
"backup_album_selection_page_total_assets": "Totaal unieke items",
|
"backup_album_selection_page_total_assets": "Totaal unieke items",
|
||||||
"backup_all": "Alle",
|
"backup_all": "Alle",
|
||||||
"backup_background_service_default_notification": "Controleren op nieuw items…",
|
"backup_background_service_default_notification": "Controleren op nieuw items…",
|
||||||
"backup_background_service_disable_battery_optimizations": "Schakel batterij optimalisatie uit voor Immich om achtergrond backup in te schakelen",
|
|
||||||
"backup_background_service_upload_failure_notification": "Fout bij upload {}",
|
"backup_background_service_upload_failure_notification": "Fout bij upload {}",
|
||||||
"backup_background_service_in_progress_notification": "Backuppen van items…",
|
"backup_background_service_in_progress_notification": "Backuppen van items…",
|
||||||
"backup_background_service_current_upload_notification": "Uploaden {}",
|
"backup_background_service_current_upload_notification": "Uploaden {}",
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
"backup_album_selection_page_total_assets": "Total de recursos exclusivos",
|
"backup_album_selection_page_total_assets": "Total de recursos exclusivos",
|
||||||
"backup_all": "Todos",
|
"backup_all": "Todos",
|
||||||
"backup_background_service_default_notification": "Checking for new assets…",
|
"backup_background_service_default_notification": "Checking for new assets…",
|
||||||
"backup_background_service_disable_battery_optimizations": "Por favor, desabilite a otimização da bateria para Immich para habilitar o backup em segundo plano",
|
|
||||||
"backup_background_service_upload_failure_notification": "Falha ao carregar {}",
|
"backup_background_service_upload_failure_notification": "Falha ao carregar {}",
|
||||||
"backup_background_service_in_progress_notification": "Fazendo backup de seus ativos…",
|
"backup_background_service_in_progress_notification": "Fazendo backup de seus ativos…",
|
||||||
"backup_background_service_current_upload_notification": "Enviando {}",
|
"backup_background_service_current_upload_notification": "Enviando {}",
|
||||||
|
|
|
@ -122,8 +122,8 @@ class BackgroundService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Opens an activity to let the user disable battery optimizations for Immich
|
/// Returns `true` if battery optimizations are disabled
|
||||||
Future<bool> disableBatteryOptimizations() async {
|
Future<bool> isIgnoringBatteryOptimizations() async {
|
||||||
if (!Platform.isAndroid) {
|
if (!Platform.isAndroid) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -131,12 +131,8 @@ class BackgroundService {
|
||||||
if (!_isForegroundInitialized) {
|
if (!_isForegroundInitialized) {
|
||||||
await _initialize();
|
await _initialize();
|
||||||
}
|
}
|
||||||
final String message =
|
return await _foregroundChannel
|
||||||
"backup_background_service_disable_battery_optimizations".tr();
|
.invokeMethod('isIgnoringBatteryOptimizations');
|
||||||
return await _foregroundChannel.invokeMethod(
|
|
||||||
'disableBatteryOptimizations',
|
|
||||||
message,
|
|
||||||
);
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -117,6 +117,7 @@ class BackupNotifier extends StateNotifier<BackUpState> {
|
||||||
bool? requireWifi,
|
bool? requireWifi,
|
||||||
bool? requireCharging,
|
bool? requireCharging,
|
||||||
required void Function(String msg) onError,
|
required void Function(String msg) onError,
|
||||||
|
required void Function() onBatteryInfo,
|
||||||
}) async {
|
}) async {
|
||||||
assert(enabled != null || requireWifi != null || requireCharging != null);
|
assert(enabled != null || requireWifi != null || requireCharging != null);
|
||||||
if (Platform.isAndroid) {
|
if (Platform.isAndroid) {
|
||||||
|
@ -131,7 +132,9 @@ class BackupNotifier extends StateNotifier<BackUpState> {
|
||||||
|
|
||||||
if (state.backgroundBackup) {
|
if (state.backgroundBackup) {
|
||||||
if (!wasEnabled) {
|
if (!wasEnabled) {
|
||||||
await _backgroundService.disableBatteryOptimizations();
|
if (!await _backgroundService.isIgnoringBatteryOptimizations()) {
|
||||||
|
onBatteryInfo();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
final bool success = await _backgroundService.stopService() &&
|
final bool success = await _backgroundService.stopService() &&
|
||||||
await _backgroundService.startService(
|
await _backgroundService.startService(
|
||||||
|
|
|
@ -14,6 +14,7 @@ import 'package:immich_mobile/routing/router.dart';
|
||||||
import 'package:immich_mobile/shared/providers/websocket.provider.dart';
|
import 'package:immich_mobile/shared/providers/websocket.provider.dart';
|
||||||
import 'package:immich_mobile/modules/backup/ui/backup_info_card.dart';
|
import 'package:immich_mobile/modules/backup/ui/backup_info_card.dart';
|
||||||
import 'package:percent_indicator/linear_percent_indicator.dart';
|
import 'package:percent_indicator/linear_percent_indicator.dart';
|
||||||
|
import 'package:url_launcher/url_launcher.dart';
|
||||||
|
|
||||||
class BackupControllerPage extends HookConsumerWidget {
|
class BackupControllerPage extends HookConsumerWidget {
|
||||||
const BackupControllerPage({Key? key}) : super(key: key);
|
const BackupControllerPage({Key? key}) : super(key: key);
|
||||||
|
@ -156,6 +157,46 @@ class BackupControllerPage extends HookConsumerWidget {
|
||||||
ScaffoldMessenger.of(context).showSnackBar(snackBar);
|
ScaffoldMessenger.of(context).showSnackBar(snackBar);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _showBatteryOptimizationInfoToUser() {
|
||||||
|
final buttonTextColor = Theme.of(context).primaryColor;
|
||||||
|
showDialog<void>(
|
||||||
|
context: context,
|
||||||
|
barrierDismissible: false,
|
||||||
|
builder: (BuildContext context) {
|
||||||
|
return AlertDialog(
|
||||||
|
title: const Text(
|
||||||
|
'backup_controller_page_background_battery_info_title',
|
||||||
|
).tr(),
|
||||||
|
content: SingleChildScrollView(
|
||||||
|
child: const Text(
|
||||||
|
'backup_controller_page_background_battery_info_message',
|
||||||
|
).tr(),
|
||||||
|
),
|
||||||
|
actions: [
|
||||||
|
TextButton(
|
||||||
|
onPressed: () => launchUrl(
|
||||||
|
Uri.parse('https://dontkillmyapp.com'),
|
||||||
|
mode: LaunchMode.externalApplication),
|
||||||
|
child: Text(
|
||||||
|
"backup_controller_page_background_battery_info_link",
|
||||||
|
style: TextStyle(color: buttonTextColor),
|
||||||
|
).tr(),
|
||||||
|
),
|
||||||
|
TextButton(
|
||||||
|
child: Text(
|
||||||
|
'backup_controller_page_background_battery_info_ok',
|
||||||
|
style: TextStyle(color: buttonTextColor),
|
||||||
|
).tr(),
|
||||||
|
onPressed: () {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
ListTile _buildBackgroundBackupController() {
|
ListTile _buildBackgroundBackupController() {
|
||||||
final bool isBackgroundEnabled = backupState.backgroundBackup;
|
final bool isBackgroundEnabled = backupState.backgroundBackup;
|
||||||
final bool isWifiRequired = backupState.backupRequireWifi;
|
final bool isWifiRequired = backupState.backupRequireWifi;
|
||||||
|
@ -197,6 +238,7 @@ class BackupControllerPage extends HookConsumerWidget {
|
||||||
.configureBackgroundBackup(
|
.configureBackgroundBackup(
|
||||||
requireWifi: isChecked,
|
requireWifi: isChecked,
|
||||||
onError: _showErrorToUser,
|
onError: _showErrorToUser,
|
||||||
|
onBatteryInfo: _showBatteryOptimizationInfoToUser,
|
||||||
)
|
)
|
||||||
: null,
|
: null,
|
||||||
),
|
),
|
||||||
|
@ -217,6 +259,7 @@ class BackupControllerPage extends HookConsumerWidget {
|
||||||
.configureBackgroundBackup(
|
.configureBackgroundBackup(
|
||||||
requireCharging: isChecked,
|
requireCharging: isChecked,
|
||||||
onError: _showErrorToUser,
|
onError: _showErrorToUser,
|
||||||
|
onBatteryInfo: _showBatteryOptimizationInfoToUser,
|
||||||
)
|
)
|
||||||
: null,
|
: null,
|
||||||
),
|
),
|
||||||
|
@ -225,6 +268,7 @@ class BackupControllerPage extends HookConsumerWidget {
|
||||||
ref.read(backupProvider.notifier).configureBackgroundBackup(
|
ref.read(backupProvider.notifier).configureBackgroundBackup(
|
||||||
enabled: !isBackgroundEnabled,
|
enabled: !isBackgroundEnabled,
|
||||||
onError: _showErrorToUser,
|
onError: _showErrorToUser,
|
||||||
|
onBatteryInfo: _showBatteryOptimizationInfoToUser,
|
||||||
),
|
),
|
||||||
child: Text(
|
child: Text(
|
||||||
isBackgroundEnabled
|
isBackgroundEnabled
|
||||||
|
|
Loading…
Reference in a new issue