fix(android): app getting killed from background

This commit is contained in:
Kingkor Roy Tirtho 2024-07-14 21:24:35 +06:00
parent e6fee03c20
commit a2ba46ea45
4 changed files with 44 additions and 26 deletions

View File

@ -31,7 +31,7 @@ if (keystorePropertiesFile.exists()) {
android { android {
compileSdkVersion 34 compileSdkVersion 34
ndkVersion "21.4.7075529" ndkVersion "25.1.8937393"
compileOptions { compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8 sourceCompatibility JavaVersion.VERSION_1_8

View File

@ -9,13 +9,15 @@ class RecentlyPlayedItemNotifier extends AsyncNotifier<List<HistoryTableData>> {
build() async { build() async {
final database = ref.watch(databaseProvider); final database = ref.watch(databaseProvider);
final uniqueItemIds = await (database.selectOnly(database.historyTable, final uniqueItemIds = await (database.selectOnly(
distinct: true) database.historyTable,
distinct: true,
)
..addColumns([database.historyTable.itemId, database.historyTable.id]) ..addColumns([database.historyTable.itemId, database.historyTable.id])
..where( ..where(
database.historyTable.type.isIn([ database.historyTable.type.isInValues([
HistoryEntryType.playlist.name, HistoryEntryType.playlist,
HistoryEntryType.album.name, HistoryEntryType.album,
]), ]),
) )
..limit(10) ..limit(10)

View File

@ -1,4 +1,5 @@
import 'package:audio_service/audio_service.dart'; import 'package:audio_service/audio_service.dart';
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:spotify/spotify.dart'; import 'package:spotify/spotify.dart';
import 'package:spotube/extensions/artist_simple.dart'; import 'package:spotube/extensions/artist_simple.dart';
@ -9,11 +10,13 @@ import 'package:spotube/services/audio_services/windows_audio_service.dart';
import 'package:spotube/services/sourced_track/sourced_track.dart'; import 'package:spotube/services/sourced_track/sourced_track.dart';
import 'package:spotube/utils/platform.dart'; import 'package:spotube/utils/platform.dart';
class AudioServices { class AudioServices with WidgetsBindingObserver {
final MobileAudioService? mobile; final MobileAudioService? mobile;
final WindowsAudioService? smtc; final WindowsAudioService? smtc;
AudioServices(this.mobile, this.smtc); AudioServices(this.mobile, this.smtc) {
WidgetsBinding.instance.addObserver(this);
}
static Future<AudioServices> create( static Future<AudioServices> create(
Ref ref, Ref ref,
@ -27,15 +30,15 @@ class AudioServices {
kIsLinux ? 'spotube' : 'com.krtirtho.Spotube', kIsLinux ? 'spotube' : 'com.krtirtho.Spotube',
androidNotificationChannelName: 'Spotube', androidNotificationChannelName: 'Spotube',
androidNotificationOngoing: true, androidNotificationOngoing: true,
androidNotificationIcon: "drawable/ic_launcher_monochrome",
androidStopForegroundOnPause: false,
androidNotificationChannelDescription: "Spotube Media Controls",
), ),
) )
: null; : null;
final smtc = kIsWindows ? WindowsAudioService(ref, playback) : null; final smtc = kIsWindows ? WindowsAudioService(ref, playback) : null;
return AudioServices( return AudioServices(mobile, smtc);
mobile,
smtc,
);
} }
Future<void> addTrack(Track track) async { Future<void> addTrack(Track track) async {
@ -65,7 +68,20 @@ class AudioServices {
mobile?.session?.setActive(false); mobile?.session?.setActive(false);
} }
@override
void didChangeAppLifecycleState(AppLifecycleState state) {
switch (state) {
case AppLifecycleState.detached:
deactivateSession();
mobile?.stop();
break;
default:
break;
}
}
void dispose() { void dispose() {
smtc?.dispose(); smtc?.dispose();
WidgetsBinding.instance.removeObserver(this);
} }
} }

View File

@ -1266,10 +1266,10 @@ packages:
dependency: "direct main" dependency: "direct main"
description: description:
name: intl name: intl
sha256: d6f56758b7d3014a48af9701c085700aac781a92a87a62b1333b46d8879661cf sha256: "3bc132a9dbce73a7e4a21a17d06e1878839ffbf975568bc875c60537824b0c4d"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "0.19.0" version: "0.18.1"
introduction_screen: introduction_screen:
dependency: "direct main" dependency: "direct main"
description: description:
@ -1322,26 +1322,26 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: leak_tracker name: leak_tracker
sha256: "7f0df31977cb2c0b88585095d168e689669a2cc9b97c309665e3386f3e9d341a" sha256: "78eb209deea09858f5269f5a5b02be4049535f568c07b275096836f01ea323fa"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "10.0.4" version: "10.0.0"
leak_tracker_flutter_testing: leak_tracker_flutter_testing:
dependency: transitive dependency: transitive
description: description:
name: leak_tracker_flutter_testing name: leak_tracker_flutter_testing
sha256: "06e98f569d004c1315b991ded39924b21af84cf14cc94791b8aea337d25b57f8" sha256: b46c5e37c19120a8a01918cfaf293547f47269f7cb4b0058f21531c2465d6ef0
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "3.0.3" version: "2.0.1"
leak_tracker_testing: leak_tracker_testing:
dependency: transitive dependency: transitive
description: description:
name: leak_tracker_testing name: leak_tracker_testing
sha256: "6ba465d5d76e67ddf503e1161d1f4a6bc42306f9d66ca1e8f079a47290fb06d3" sha256: a597f72a664dbd293f3bfc51f9ba69816f84dcd403cdac7066cb3f6003f3ab47
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "3.0.1" version: "2.0.1"
lints: lints:
dependency: transitive dependency: transitive
description: description:
@ -1474,10 +1474,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: meta name: meta
sha256: "7687075e408b093f36e6bbf6c91878cc0d4cd10f409506f7bc996f68220b9136" sha256: d584fa6707a52763a52446f02cc621b077888fb63b93bbcb1143a7be5a0c0c04
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "1.12.0" version: "1.11.0"
metadata_god: metadata_god:
dependency: "direct main" dependency: "direct main"
description: description:
@ -2186,10 +2186,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: test_api name: test_api
sha256: "9955ae474176f7ac8ee4e989dadfb411a58c30415bcfb648fa04b2b8a03afa7f" sha256: "5c2f730018264d276c20e4f1503fd1308dfbbae39ec8ee63c5236311ac06954b"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "0.7.0" version: "0.6.1"
time: time:
dependency: transitive dependency: transitive
description: description:
@ -2394,10 +2394,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: vm_service name: vm_service
sha256: "3923c89304b715fb1eb6423f017651664a03bf5f4b29983627c4da791f74a4ec" sha256: b3d56ff4341b8f182b96aceb2fa20e3dcb336b9f867bc0eafc0de10f1048e957
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "14.2.1" version: "13.0.0"
watcher: watcher:
dependency: transitive dependency: transitive
description: description: