react-native-nitro-player 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/NitroPlayer.podspec +31 -0
- package/README.md +610 -0
- package/android/CMakeLists.txt +29 -0
- package/android/build.gradle +147 -0
- package/android/fix-prefab.gradle +51 -0
- package/android/gradle.properties +5 -0
- package/android/src/main/AndroidManifest.xml +2 -0
- package/android/src/main/cpp/cpp-adapter.cpp +7 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrary.kt +29 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAudioDevices.kt +116 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridPlayerQueue.kt +167 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridTrackPlayer.kt +93 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/NitroPlayerPackage.kt +21 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/connection/AndroidAutoConnectionDetector.kt +171 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/core/TrackPlayerCore.kt +639 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaBrowserService.kt +352 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibrary.kt +58 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibraryManager.kt +77 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibraryParser.kt +73 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaSessionManager.kt +506 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/Playlist.kt +21 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/PlaylistManager.kt +454 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/queue/Queue.kt +94 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/queue/QueueManager.kt +143 -0
- package/ios/HybridAudioRoutePicker.swift +53 -0
- package/ios/HybridTrackPlayer.swift +100 -0
- package/ios/core/TrackPlayerCore.swift +1040 -0
- package/ios/media/MediaSessionManager.swift +230 -0
- package/ios/playlist/PlaylistManager.swift +446 -0
- package/ios/playlist/PlaylistModel.swift +49 -0
- package/ios/queue/HybridPlayerQueue.swift +95 -0
- package/ios/queue/Queue.swift +126 -0
- package/ios/queue/QueueManager.swift +157 -0
- package/lib/hooks/index.d.ts +6 -0
- package/lib/hooks/index.js +6 -0
- package/lib/hooks/useAndroidAutoConnection.d.ts +13 -0
- package/lib/hooks/useAndroidAutoConnection.js +26 -0
- package/lib/hooks/useAudioDevices.d.ts +26 -0
- package/lib/hooks/useAudioDevices.js +55 -0
- package/lib/hooks/useOnChangeTrack.d.ts +9 -0
- package/lib/hooks/useOnChangeTrack.js +17 -0
- package/lib/hooks/useOnPlaybackProgressChange.d.ts +9 -0
- package/lib/hooks/useOnPlaybackProgressChange.js +19 -0
- package/lib/hooks/useOnPlaybackStateChange.d.ts +9 -0
- package/lib/hooks/useOnPlaybackStateChange.js +17 -0
- package/lib/hooks/useOnSeek.d.ts +8 -0
- package/lib/hooks/useOnSeek.js +17 -0
- package/lib/index.d.ts +14 -0
- package/lib/index.js +24 -0
- package/lib/specs/AndroidAutoMediaLibrary.nitro.d.ts +21 -0
- package/lib/specs/AndroidAutoMediaLibrary.nitro.js +1 -0
- package/lib/specs/AudioDevices.nitro.d.ts +24 -0
- package/lib/specs/AudioDevices.nitro.js +1 -0
- package/lib/specs/AudioRoutePicker.nitro.d.ts +10 -0
- package/lib/specs/AudioRoutePicker.nitro.js +1 -0
- package/lib/specs/TrackPlayer.nitro.d.ts +39 -0
- package/lib/specs/TrackPlayer.nitro.js +1 -0
- package/lib/types/AndroidAutoMediaLibrary.d.ts +44 -0
- package/lib/types/AndroidAutoMediaLibrary.js +1 -0
- package/lib/types/PlayerQueue.d.ts +32 -0
- package/lib/types/PlayerQueue.js +1 -0
- package/lib/utils/androidAutoMediaLibrary.d.ts +47 -0
- package/lib/utils/androidAutoMediaLibrary.js +62 -0
- package/nitro.json +31 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/android/NitroPlayer+autolinking.cmake +91 -0
- package/nitrogen/generated/android/NitroPlayer+autolinking.gradle +27 -0
- package/nitrogen/generated/android/NitroPlayerOnLoad.cpp +88 -0
- package/nitrogen/generated/android/NitroPlayerOnLoad.hpp +25 -0
- package/nitrogen/generated/android/c++/JFunc_void_TrackItem_std__optional_Reason_.hpp +85 -0
- package/nitrogen/generated/android/c++/JFunc_void_TrackPlayerState_std__optional_Reason_.hpp +80 -0
- package/nitrogen/generated/android/c++/JFunc_void_bool.hpp +75 -0
- package/nitrogen/generated/android/c++/JFunc_void_double_double.hpp +75 -0
- package/nitrogen/generated/android/c++/JFunc_void_double_double_std__optional_bool_.hpp +76 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__string_Playlist_std__optional_QueueOperation_.hpp +88 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__vector_Playlist__std__optional_QueueOperation_.hpp +106 -0
- package/nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.cpp +55 -0
- package/nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.hpp +66 -0
- package/nitrogen/generated/android/c++/JHybridAudioDevicesSpec.cpp +70 -0
- package/nitrogen/generated/android/c++/JHybridAudioDevicesSpec.hpp +66 -0
- package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.cpp +143 -0
- package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.hpp +77 -0
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp +137 -0
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.hpp +78 -0
- package/nitrogen/generated/android/c++/JPlayerConfig.hpp +65 -0
- package/nitrogen/generated/android/c++/JPlayerState.hpp +87 -0
- package/nitrogen/generated/android/c++/JPlaylist.hpp +99 -0
- package/nitrogen/generated/android/c++/JQueueOperation.hpp +65 -0
- package/nitrogen/generated/android/c++/JReason.hpp +65 -0
- package/nitrogen/generated/android/c++/JTAudioDevice.hpp +69 -0
- package/nitrogen/generated/android/c++/JTrackItem.hpp +86 -0
- package/nitrogen/generated/android/c++/JTrackPlayerState.hpp +62 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.hpp +77 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_String.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_String.hpp +70 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.hpp +74 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_TrackItem_std__optional_Reason_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_TrackPlayerState_std__optional_Reason_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_bool.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_double_double.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_double_double_std__optional_bool_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__string_Playlist_std__optional_QueueOperation_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__vector_Playlist__std__optional_QueueOperation_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrarySpec.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridAudioDevicesSpec.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridPlayerQueueSpec.kt +116 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt +134 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/NitroPlayerOnLoad.kt +35 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerConfig.kt +44 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerState.kt +53 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Playlist.kt +50 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/QueueOperation.kt +23 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Reason.kt +23 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TAudioDevice.kt +47 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackItem.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackPlayerState.kt +22 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_Playlist.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_String.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_TrackItem.kt +59 -0
- package/nitrogen/generated/ios/NitroPlayer+autolinking.rb +60 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.cpp +123 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.hpp +531 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Umbrella.hpp +80 -0
- package/nitrogen/generated/ios/NitroPlayerAutolinking.mm +49 -0
- package/nitrogen/generated/ios/NitroPlayerAutolinking.swift +55 -0
- package/nitrogen/generated/ios/c++/HybridAudioRoutePickerSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridAudioRoutePickerSpecSwift.hpp +74 -0
- package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.hpp +167 -0
- package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.hpp +174 -0
- package/nitrogen/generated/ios/swift/Func_void_TrackItem_std__optional_Reason_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_TrackPlayerState_std__optional_Reason_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_bool.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_double_double.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_double_double_std__optional_bool_.swift +54 -0
- package/nitrogen/generated/ios/swift/Func_void_std__string_Playlist_std__optional_QueueOperation_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_Playlist__std__optional_QueueOperation_.swift +47 -0
- package/nitrogen/generated/ios/swift/HybridAudioRoutePickerSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/HybridAudioRoutePickerSpec_cxx.swift +130 -0
- package/nitrogen/generated/ios/swift/HybridPlayerQueueSpec.swift +68 -0
- package/nitrogen/generated/ios/swift/HybridPlayerQueueSpec_cxx.swift +349 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec.swift +69 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec_cxx.swift +325 -0
- package/nitrogen/generated/ios/swift/PlayerConfig.swift +115 -0
- package/nitrogen/generated/ios/swift/PlayerState.swift +181 -0
- package/nitrogen/generated/ios/swift/Playlist.swift +182 -0
- package/nitrogen/generated/ios/swift/QueueOperation.swift +48 -0
- package/nitrogen/generated/ios/swift/Reason.swift +48 -0
- package/nitrogen/generated/ios/swift/TrackItem.swift +147 -0
- package/nitrogen/generated/ios/swift/TrackPlayerState.swift +44 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_Playlist.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_String.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_TrackItem.swift +18 -0
- package/nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.hpp +63 -0
- package/nitrogen/generated/shared/c++/HybridAudioDevicesSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridAudioDevicesSpec.hpp +65 -0
- package/nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.cpp +21 -0
- package/nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.hpp +62 -0
- package/nitrogen/generated/shared/c++/HybridPlayerQueueSpec.cpp +33 -0
- package/nitrogen/generated/shared/c++/HybridPlayerQueueSpec.hpp +87 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp +34 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.hpp +91 -0
- package/nitrogen/generated/shared/c++/PlayerConfig.hpp +83 -0
- package/nitrogen/generated/shared/c++/PlayerState.hpp +103 -0
- package/nitrogen/generated/shared/c++/Playlist.hpp +97 -0
- package/nitrogen/generated/shared/c++/QueueOperation.hpp +84 -0
- package/nitrogen/generated/shared/c++/Reason.hpp +84 -0
- package/nitrogen/generated/shared/c++/TAudioDevice.hpp +87 -0
- package/nitrogen/generated/shared/c++/TrackItem.hpp +102 -0
- package/nitrogen/generated/shared/c++/TrackPlayerState.hpp +80 -0
- package/package.json +172 -0
- package/react-native.config.js +16 -0
- package/src/hooks/index.ts +6 -0
- package/src/hooks/useAndroidAutoConnection.ts +30 -0
- package/src/hooks/useAudioDevices.ts +64 -0
- package/src/hooks/useOnChangeTrack.ts +24 -0
- package/src/hooks/useOnPlaybackProgressChange.ts +30 -0
- package/src/hooks/useOnPlaybackStateChange.ts +24 -0
- package/src/hooks/useOnSeek.ts +25 -0
- package/src/index.ts +47 -0
- package/src/specs/AndroidAutoMediaLibrary.nitro.ts +22 -0
- package/src/specs/AudioDevices.nitro.ts +25 -0
- package/src/specs/AudioRoutePicker.nitro.ts +9 -0
- package/src/specs/TrackPlayer.nitro.ts +81 -0
- package/src/types/AndroidAutoMediaLibrary.ts +58 -0
- package/src/types/PlayerQueue.ts +38 -0
- package/src/utils/androidAutoMediaLibrary.ts +66 -0
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
//
|
|
2
|
+
// HybridPlayerQueue.swift
|
|
3
|
+
// NitroPlayer
|
|
4
|
+
//
|
|
5
|
+
// Created by Ritesh Shukla on 24/11/25.
|
|
6
|
+
//
|
|
7
|
+
|
|
8
|
+
import NitroModules
|
|
9
|
+
|
|
10
|
+
final class HybridPlayerQueue: HybridPlayerQueueSpec {
|
|
11
|
+
private let playlistManager = PlaylistManager.shared
|
|
12
|
+
private var playlistsChangeListener: (() -> Void)?
|
|
13
|
+
private var playlistChangeListeners: [String: () -> Void] = [:]
|
|
14
|
+
|
|
15
|
+
func createPlaylist(name: String, description: String?, artwork: String?) throws -> String {
|
|
16
|
+
return playlistManager.createPlaylist(name: name, description: description, artwork: artwork)
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
func deletePlaylist(playlistId: String) throws {
|
|
20
|
+
_ = playlistManager.deletePlaylist(playlistId: playlistId)
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
func updatePlaylist(playlistId: String, name: String?, description: String?, artwork: String?)
|
|
24
|
+
throws
|
|
25
|
+
{
|
|
26
|
+
_ = playlistManager.updatePlaylist(
|
|
27
|
+
playlistId: playlistId, name: name, description: description, artwork: artwork)
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
func getPlaylist(playlistId: String) throws -> Variant_NullType_Playlist {
|
|
31
|
+
if let playlist = playlistManager.getPlaylist(playlistId: playlistId) {
|
|
32
|
+
return Variant_NullType_Playlist.second(playlist.toGeneratedPlaylist())
|
|
33
|
+
} else {
|
|
34
|
+
return Variant_NullType_Playlist.first(NullType.null)
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
func getAllPlaylists() throws -> [Playlist] {
|
|
39
|
+
return playlistManager.getAllPlaylists().map { $0.toGeneratedPlaylist() }
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
func addTrackToPlaylist(playlistId: String, track: TrackItem, index: Double?) throws {
|
|
43
|
+
let insertIndex = index.map { Int($0) }
|
|
44
|
+
_ = playlistManager.addTrackToPlaylist(playlistId: playlistId, track: track, index: insertIndex)
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
func addTracksToPlaylist(playlistId: String, tracks: [TrackItem], index: Double?) throws {
|
|
48
|
+
let insertIndex = index.map { Int($0) }
|
|
49
|
+
_ = playlistManager.addTracksToPlaylist(
|
|
50
|
+
playlistId: playlistId, tracks: tracks, index: insertIndex)
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
func removeTrackFromPlaylist(playlistId: String, trackId: String) throws {
|
|
54
|
+
_ = playlistManager.removeTrackFromPlaylist(playlistId: playlistId, trackId: trackId)
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
func reorderTrackInPlaylist(playlistId: String, trackId: String, newIndex: Double) throws {
|
|
58
|
+
_ = playlistManager.reorderTrackInPlaylist(
|
|
59
|
+
playlistId: playlistId, trackId: trackId, newIndex: Int(newIndex))
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
func loadPlaylist(playlistId: String) throws {
|
|
63
|
+
_ = playlistManager.loadPlaylist(playlistId: playlistId)
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
func getCurrentPlaylistId() throws -> Variant_NullType_String {
|
|
67
|
+
if let playlistId = playlistManager.getCurrentPlaylistId() {
|
|
68
|
+
return Variant_NullType_String.second(playlistId)
|
|
69
|
+
} else {
|
|
70
|
+
return Variant_NullType_String.first(NullType.null)
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
func onPlaylistsChanged(callback: @escaping ([Playlist], QueueOperation?) -> Void) throws {
|
|
75
|
+
// Remove previous listener if exists
|
|
76
|
+
playlistsChangeListener?()
|
|
77
|
+
|
|
78
|
+
// Add new listener
|
|
79
|
+
playlistsChangeListener = playlistManager.addPlaylistsChangeListener { playlists, operation in
|
|
80
|
+
callback(playlists.map { $0.toGeneratedPlaylist() }, operation)
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
func onPlaylistChanged(callback: @escaping (String, Playlist, QueueOperation?) -> Void) throws {
|
|
85
|
+
// Listen to all playlists
|
|
86
|
+
let allPlaylists = playlistManager.getAllPlaylists()
|
|
87
|
+
for playlist in allPlaylists {
|
|
88
|
+
let removeListener = playlistManager.addPlaylistChangeListener(playlistId: playlist.id) {
|
|
89
|
+
updatedPlaylist, operation in
|
|
90
|
+
callback(updatedPlaylist.id, updatedPlaylist.toGeneratedPlaylist(), operation)
|
|
91
|
+
}
|
|
92
|
+
playlistChangeListeners[playlist.id] = removeListener
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Queue.swift
|
|
3
|
+
// NitroPlayer
|
|
4
|
+
//
|
|
5
|
+
// Created by Ritesh Shukla on 24/11/25.
|
|
6
|
+
//
|
|
7
|
+
|
|
8
|
+
import Foundation
|
|
9
|
+
|
|
10
|
+
/// Queue class that manages a list of tracks.
|
|
11
|
+
/// Thread-safe implementation using a serial dispatch queue.
|
|
12
|
+
class Queue {
|
|
13
|
+
private var tracks: [TrackItem] = []
|
|
14
|
+
private let queue = DispatchQueue(label: "com.margelo.nitro.nitroplayer.queue")
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Get all tracks in the queue
|
|
18
|
+
*/
|
|
19
|
+
func getTracks() -> [TrackItem] {
|
|
20
|
+
return queue.sync {
|
|
21
|
+
return Array(tracks)
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Add a single track to the queue
|
|
27
|
+
*/
|
|
28
|
+
func addTrack(_ track: TrackItem) {
|
|
29
|
+
queue.sync {
|
|
30
|
+
self.tracks.append(track)
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Add a track at a specific index
|
|
36
|
+
*/
|
|
37
|
+
func addTrackAtIndex(_ track: TrackItem, index: Int) {
|
|
38
|
+
queue.sync {
|
|
39
|
+
if index < 0 || index > self.tracks.count {
|
|
40
|
+
self.tracks.append(track)
|
|
41
|
+
} else {
|
|
42
|
+
self.tracks.insert(track, at: index)
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Load multiple tracks into the queue (replaces existing queue)
|
|
49
|
+
*/
|
|
50
|
+
func loadTracks(_ newTracks: [TrackItem]) {
|
|
51
|
+
queue.sync {
|
|
52
|
+
self.tracks.removeAll()
|
|
53
|
+
self.tracks.append(contentsOf: newTracks)
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Remove a track by ID
|
|
59
|
+
* @return true if track was found and removed, false otherwise
|
|
60
|
+
*/
|
|
61
|
+
func removeTrack(id: String) -> Bool {
|
|
62
|
+
return queue.sync {
|
|
63
|
+
let initialCount = self.tracks.count
|
|
64
|
+
self.tracks.removeAll { $0.id == id }
|
|
65
|
+
return self.tracks.count < initialCount
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Clear all tracks from the queue
|
|
71
|
+
*/
|
|
72
|
+
func clear() {
|
|
73
|
+
queue.sync {
|
|
74
|
+
self.tracks.removeAll()
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Get the size of the queue
|
|
80
|
+
*/
|
|
81
|
+
func size() -> Int {
|
|
82
|
+
return queue.sync {
|
|
83
|
+
return self.tracks.count
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
/**
|
|
88
|
+
* Check if the queue is empty
|
|
89
|
+
*/
|
|
90
|
+
func isEmpty() -> Bool {
|
|
91
|
+
return queue.sync {
|
|
92
|
+
return self.tracks.isEmpty
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Get a track by index
|
|
98
|
+
*/
|
|
99
|
+
func getTrack(index: Int) -> TrackItem? {
|
|
100
|
+
return queue.sync {
|
|
101
|
+
if index >= 0 && index < self.tracks.count {
|
|
102
|
+
return self.tracks[index]
|
|
103
|
+
} else {
|
|
104
|
+
return nil
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Get a track by ID
|
|
111
|
+
*/
|
|
112
|
+
func getTrackById(id: String) -> TrackItem? {
|
|
113
|
+
return queue.sync {
|
|
114
|
+
return self.tracks.first { $0.id == id }
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Get the index of a track by ID
|
|
120
|
+
*/
|
|
121
|
+
func getTrackIndex(id: String) -> Int {
|
|
122
|
+
return queue.sync {
|
|
123
|
+
return self.tracks.firstIndex { $0.id == id } ?? -1
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
//
|
|
2
|
+
// QueueManager.swift
|
|
3
|
+
// NitroPlayer
|
|
4
|
+
//
|
|
5
|
+
// Created by Ritesh Shukla on 24/11/25.
|
|
6
|
+
//
|
|
7
|
+
|
|
8
|
+
import Foundation
|
|
9
|
+
|
|
10
|
+
/// Wrapper class to store listeners with unique IDs for removal
|
|
11
|
+
private class ListenerWrapper {
|
|
12
|
+
let id: UUID
|
|
13
|
+
let listener: ([TrackItem], QueueOperation?) -> Void
|
|
14
|
+
|
|
15
|
+
init(id: UUID = UUID(), listener: @escaping ([TrackItem], QueueOperation?) -> Void) {
|
|
16
|
+
self.id = id
|
|
17
|
+
self.listener = listener
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/// QueueManager is a singleton that manages the queue state across the app session.
|
|
22
|
+
/// It provides thread-safe access to the queue and notifies listeners of queue changes.
|
|
23
|
+
class QueueManager {
|
|
24
|
+
private let queue = Queue()
|
|
25
|
+
private var listeners: [ListenerWrapper] = []
|
|
26
|
+
private let listenersQueue = DispatchQueue(label: "com.margelo.nitro.nitroplayer.listeners")
|
|
27
|
+
|
|
28
|
+
static let shared = QueueManager()
|
|
29
|
+
|
|
30
|
+
private init() {}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Get the current queue
|
|
34
|
+
*/
|
|
35
|
+
func getQueue() -> Queue {
|
|
36
|
+
return queue
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Get all tracks in the queue
|
|
41
|
+
*/
|
|
42
|
+
func getTracks() -> [TrackItem] {
|
|
43
|
+
return queue.getTracks()
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Load multiple tracks into the queue (replaces existing queue)
|
|
48
|
+
*/
|
|
49
|
+
func loadQueue(_ tracks: [TrackItem]) {
|
|
50
|
+
queue.loadTracks(tracks)
|
|
51
|
+
notifyListeners(.add)
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Load a single track at a specific index
|
|
56
|
+
*/
|
|
57
|
+
func loadSingleTrack(_ track: TrackItem, index: Double?) {
|
|
58
|
+
let insertIndex = index.map { Int($0) }
|
|
59
|
+
if let insertIndex = insertIndex, insertIndex >= 0 {
|
|
60
|
+
queue.addTrackAtIndex(track, index: insertIndex)
|
|
61
|
+
} else {
|
|
62
|
+
queue.addTrack(track)
|
|
63
|
+
}
|
|
64
|
+
notifyListeners(.add)
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Delete a track by ID
|
|
69
|
+
*/
|
|
70
|
+
func deleteTrack(id: String) {
|
|
71
|
+
let removed = queue.removeTrack(id: id)
|
|
72
|
+
if removed {
|
|
73
|
+
notifyListeners(.remove)
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* Clear all tracks from the queue
|
|
79
|
+
*/
|
|
80
|
+
func clearQueue() {
|
|
81
|
+
queue.clear()
|
|
82
|
+
notifyListeners(.clear)
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Add a listener for queue changes
|
|
87
|
+
* @param listener Callback that receives (queue, operation)
|
|
88
|
+
* @return A function to remove the listener
|
|
89
|
+
*/
|
|
90
|
+
func addQueueChangeListener(
|
|
91
|
+
_ listener: @escaping (_ queue: [TrackItem], _ operation: QueueOperation?) -> Void
|
|
92
|
+
) -> () -> Void {
|
|
93
|
+
let wrapper = ListenerWrapper(listener: listener)
|
|
94
|
+
listenersQueue.sync {
|
|
95
|
+
listeners.append(wrapper)
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
return { [weak self, wrapper] in
|
|
99
|
+
self?.listenersQueue.sync {
|
|
100
|
+
self?.listeners.removeAll { $0.id == wrapper.id }
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Notify all listeners of queue changes
|
|
107
|
+
*/
|
|
108
|
+
private func notifyListeners(_ operation: QueueOperation?) {
|
|
109
|
+
let currentTracks = queue.getTracks()
|
|
110
|
+
listenersQueue.sync {
|
|
111
|
+
let listenersCopy = listeners
|
|
112
|
+
for wrapper in listenersCopy {
|
|
113
|
+
do {
|
|
114
|
+
wrapper.listener(currentTracks, operation)
|
|
115
|
+
} catch {
|
|
116
|
+
// Log error but don't break other listeners
|
|
117
|
+
print("Error in queue change listener: \(error)")
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Get queue size
|
|
125
|
+
*/
|
|
126
|
+
func getQueueSize() -> Int {
|
|
127
|
+
return queue.size()
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Check if queue is empty
|
|
132
|
+
*/
|
|
133
|
+
func isQueueEmpty() -> Bool {
|
|
134
|
+
return queue.isEmpty()
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Get a track by index
|
|
139
|
+
*/
|
|
140
|
+
func getTrack(index: Int) -> TrackItem? {
|
|
141
|
+
return queue.getTrack(index: index)
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Get a track by ID
|
|
146
|
+
*/
|
|
147
|
+
func getTrackById(id: String) -> TrackItem? {
|
|
148
|
+
return queue.getTrackById(id: id)
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
/**
|
|
152
|
+
* Get the index of a track by ID
|
|
153
|
+
*/
|
|
154
|
+
func getTrackIndex(id: String) -> Int {
|
|
155
|
+
return queue.getTrackIndex(id: id)
|
|
156
|
+
}
|
|
157
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { useOnChangeTrack } from './useOnChangeTrack';
|
|
2
|
+
export { useOnPlaybackStateChange } from './useOnPlaybackStateChange';
|
|
3
|
+
export { useOnSeek } from './useOnSeek';
|
|
4
|
+
export { useOnPlaybackProgressChange } from './useOnPlaybackProgressChange';
|
|
5
|
+
export { useAndroidAutoConnection } from './useAndroidAutoConnection';
|
|
6
|
+
export { useAudioDevices } from './useAudioDevices';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { useOnChangeTrack } from './useOnChangeTrack';
|
|
2
|
+
export { useOnPlaybackStateChange } from './useOnPlaybackStateChange';
|
|
3
|
+
export { useOnSeek } from './useOnSeek';
|
|
4
|
+
export { useOnPlaybackProgressChange } from './useOnPlaybackProgressChange';
|
|
5
|
+
export { useAndroidAutoConnection } from './useAndroidAutoConnection';
|
|
6
|
+
export { useAudioDevices } from './useAudioDevices';
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook to detect Android Auto connection status using the official Android for Cars API
|
|
3
|
+
* Based on: https://developer.android.com/training/cars/apps#car-connection
|
|
4
|
+
*
|
|
5
|
+
* @returns Object with isConnected boolean
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* const { isConnected } = useAndroidAutoConnection();
|
|
9
|
+
* console.log('Android Auto connected:', isConnected);
|
|
10
|
+
*/
|
|
11
|
+
export declare function useAndroidAutoConnection(): {
|
|
12
|
+
isConnected: boolean;
|
|
13
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { TrackPlayer } from '../index';
|
|
3
|
+
/**
|
|
4
|
+
* Hook to detect Android Auto connection status using the official Android for Cars API
|
|
5
|
+
* Based on: https://developer.android.com/training/cars/apps#car-connection
|
|
6
|
+
*
|
|
7
|
+
* @returns Object with isConnected boolean
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* const { isConnected } = useAndroidAutoConnection();
|
|
11
|
+
* console.log('Android Auto connected:', isConnected);
|
|
12
|
+
*/
|
|
13
|
+
export function useAndroidAutoConnection() {
|
|
14
|
+
const [isConnected, setIsConnected] = useState(false);
|
|
15
|
+
useEffect(() => {
|
|
16
|
+
// Set initial state
|
|
17
|
+
const initialState = TrackPlayer.isAndroidAutoConnected();
|
|
18
|
+
setIsConnected(initialState);
|
|
19
|
+
// Listen for connection changes
|
|
20
|
+
TrackPlayer.onAndroidAutoConnectionChange((connected) => {
|
|
21
|
+
setIsConnected(connected);
|
|
22
|
+
console.log('🚗 Android Auto connection changed:', connected);
|
|
23
|
+
});
|
|
24
|
+
}, []);
|
|
25
|
+
return { isConnected };
|
|
26
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { TAudioDevice } from '../specs/AudioDevices.nitro';
|
|
2
|
+
/**
|
|
3
|
+
* Hook to get audio devices (Android only)
|
|
4
|
+
*
|
|
5
|
+
* Polls for device changes every 2 seconds
|
|
6
|
+
*
|
|
7
|
+
* @returns Object containing the current list of audio devices
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```tsx
|
|
11
|
+
* function MyComponent() {
|
|
12
|
+
* const { devices } = useAudioDevices()
|
|
13
|
+
*
|
|
14
|
+
* return (
|
|
15
|
+
* <View>
|
|
16
|
+
* {devices.map(device => (
|
|
17
|
+
* <Text key={device.id}>{device.name}</Text>
|
|
18
|
+
* ))}
|
|
19
|
+
* </View>
|
|
20
|
+
* )
|
|
21
|
+
* }
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
export declare function useAudioDevices(): {
|
|
25
|
+
devices: TAudioDevice[];
|
|
26
|
+
};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { Platform } from 'react-native';
|
|
3
|
+
import { NitroModules } from 'react-native-nitro-modules';
|
|
4
|
+
/**
|
|
5
|
+
* Hook to get audio devices (Android only)
|
|
6
|
+
*
|
|
7
|
+
* Polls for device changes every 2 seconds
|
|
8
|
+
*
|
|
9
|
+
* @returns Object containing the current list of audio devices
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* function MyComponent() {
|
|
14
|
+
* const { devices } = useAudioDevices()
|
|
15
|
+
*
|
|
16
|
+
* return (
|
|
17
|
+
* <View>
|
|
18
|
+
* {devices.map(device => (
|
|
19
|
+
* <Text key={device.id}>{device.name}</Text>
|
|
20
|
+
* ))}
|
|
21
|
+
* </View>
|
|
22
|
+
* )
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export function useAudioDevices() {
|
|
27
|
+
const [devices, setDevices] = useState([]);
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
if (Platform.OS !== 'android') {
|
|
30
|
+
return undefined;
|
|
31
|
+
}
|
|
32
|
+
try {
|
|
33
|
+
const AudioDevices = NitroModules.createHybridObject('AudioDevices');
|
|
34
|
+
// Get initial devices
|
|
35
|
+
const updateDevices = () => {
|
|
36
|
+
try {
|
|
37
|
+
const currentDevices = AudioDevices.getAudioDevices();
|
|
38
|
+
setDevices(currentDevices);
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
console.error('Error getting audio devices:', error);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
updateDevices();
|
|
45
|
+
// Poll for changes every 2 seconds
|
|
46
|
+
const interval = setInterval(updateDevices, 2000);
|
|
47
|
+
return () => clearInterval(interval);
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
console.error('Error setting up audio devices polling:', error);
|
|
51
|
+
return undefined;
|
|
52
|
+
}
|
|
53
|
+
}, []);
|
|
54
|
+
return { devices };
|
|
55
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TrackItem, Reason } from '../types/PlayerQueue';
|
|
2
|
+
/**
|
|
3
|
+
* Hook to get the current track and track change reason
|
|
4
|
+
* @returns Object with current track and reason, or undefined if no track is playing
|
|
5
|
+
*/
|
|
6
|
+
export declare function useOnChangeTrack(): {
|
|
7
|
+
track: TrackItem | undefined;
|
|
8
|
+
reason: Reason | undefined;
|
|
9
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { TrackPlayer } from '../index';
|
|
3
|
+
/**
|
|
4
|
+
* Hook to get the current track and track change reason
|
|
5
|
+
* @returns Object with current track and reason, or undefined if no track is playing
|
|
6
|
+
*/
|
|
7
|
+
export function useOnChangeTrack() {
|
|
8
|
+
const [track, setTrack] = useState(undefined);
|
|
9
|
+
const [reason, setReason] = useState(undefined);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
TrackPlayer.onChangeTrack((newTrack, newReason) => {
|
|
12
|
+
setTrack(newTrack);
|
|
13
|
+
setReason(newReason);
|
|
14
|
+
});
|
|
15
|
+
}, []);
|
|
16
|
+
return { track, reason };
|
|
17
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook to get the current playback progress
|
|
3
|
+
* @returns Object with current position, total duration, and manual seek indicator
|
|
4
|
+
*/
|
|
5
|
+
export declare function useOnPlaybackProgressChange(): {
|
|
6
|
+
position: number;
|
|
7
|
+
totalDuration: number;
|
|
8
|
+
isManuallySeeked: boolean | undefined;
|
|
9
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { TrackPlayer } from '../index';
|
|
3
|
+
/**
|
|
4
|
+
* Hook to get the current playback progress
|
|
5
|
+
* @returns Object with current position, total duration, and manual seek indicator
|
|
6
|
+
*/
|
|
7
|
+
export function useOnPlaybackProgressChange() {
|
|
8
|
+
const [position, setPosition] = useState(0);
|
|
9
|
+
const [totalDuration, setTotalDuration] = useState(0);
|
|
10
|
+
const [isManuallySeeked, setIsManuallySeeked] = useState(undefined);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
TrackPlayer.onPlaybackProgressChange((newPosition, newTotalDuration, newIsManuallySeeked) => {
|
|
13
|
+
setPosition(newPosition);
|
|
14
|
+
setTotalDuration(newTotalDuration);
|
|
15
|
+
setIsManuallySeeked(newIsManuallySeeked);
|
|
16
|
+
});
|
|
17
|
+
}, []);
|
|
18
|
+
return { position, totalDuration, isManuallySeeked };
|
|
19
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TrackPlayerState, Reason } from '../types/PlayerQueue';
|
|
2
|
+
/**
|
|
3
|
+
* Hook to get the current playback state and reason
|
|
4
|
+
* @returns Object with current playback state and reason
|
|
5
|
+
*/
|
|
6
|
+
export declare function useOnPlaybackStateChange(): {
|
|
7
|
+
state: TrackPlayerState | undefined;
|
|
8
|
+
reason: Reason | undefined;
|
|
9
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { TrackPlayer } from '../index';
|
|
3
|
+
/**
|
|
4
|
+
* Hook to get the current playback state and reason
|
|
5
|
+
* @returns Object with current playback state and reason
|
|
6
|
+
*/
|
|
7
|
+
export function useOnPlaybackStateChange() {
|
|
8
|
+
const [state, setState] = useState(undefined);
|
|
9
|
+
const [reason, setReason] = useState(undefined);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
TrackPlayer.onPlaybackStateChange((newState, newReason) => {
|
|
12
|
+
setState(newState);
|
|
13
|
+
setReason(newReason);
|
|
14
|
+
});
|
|
15
|
+
}, []);
|
|
16
|
+
return { state, reason };
|
|
17
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook to get the last seek event information
|
|
3
|
+
* @returns Object with last seek position and total duration, or undefined if no seek has occurred
|
|
4
|
+
*/
|
|
5
|
+
export declare function useOnSeek(): {
|
|
6
|
+
position: number | undefined;
|
|
7
|
+
totalDuration: number | undefined;
|
|
8
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
import { TrackPlayer } from '../index';
|
|
3
|
+
/**
|
|
4
|
+
* Hook to get the last seek event information
|
|
5
|
+
* @returns Object with last seek position and total duration, or undefined if no seek has occurred
|
|
6
|
+
*/
|
|
7
|
+
export function useOnSeek() {
|
|
8
|
+
const [position, setPosition] = useState(undefined);
|
|
9
|
+
const [totalDuration, setTotalDuration] = useState(undefined);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
TrackPlayer.onSeek((newPosition, newTotalDuration) => {
|
|
12
|
+
setPosition(newPosition);
|
|
13
|
+
setTotalDuration(newTotalDuration);
|
|
14
|
+
});
|
|
15
|
+
}, []);
|
|
16
|
+
return { position, totalDuration };
|
|
17
|
+
}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { PlayerQueue as PlayerQueueType, TrackPlayer as TrackPlayerType } from './specs/TrackPlayer.nitro';
|
|
2
|
+
import type { AndroidAutoMediaLibrary as AndroidAutoMediaLibraryType } from './specs/AndroidAutoMediaLibrary.nitro';
|
|
3
|
+
import type { AudioDevices as AudioDevicesType } from './specs/AudioDevices.nitro';
|
|
4
|
+
import type { AudioRoutePicker as AudioRoutePickerType } from './specs/AudioRoutePicker.nitro';
|
|
5
|
+
export declare const PlayerQueue: PlayerQueueType;
|
|
6
|
+
export declare const TrackPlayer: TrackPlayerType;
|
|
7
|
+
export declare const AndroidAutoMediaLibrary: AndroidAutoMediaLibraryType | null;
|
|
8
|
+
export declare const AudioDevices: AudioDevicesType | null;
|
|
9
|
+
export declare const AudioRoutePicker: AudioRoutePickerType | null;
|
|
10
|
+
export * from './hooks';
|
|
11
|
+
export * from './types/PlayerQueue';
|
|
12
|
+
export * from './types/AndroidAutoMediaLibrary';
|
|
13
|
+
export type { TAudioDevice } from './specs/AudioDevices.nitro';
|
|
14
|
+
export { AndroidAutoMediaLibraryHelper } from './utils/androidAutoMediaLibrary';
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// TODO: Export all HybridObjects here for the user
|
|
2
|
+
import { NitroModules } from 'react-native-nitro-modules';
|
|
3
|
+
import { Platform } from 'react-native';
|
|
4
|
+
export const PlayerQueue = NitroModules.createHybridObject('PlayerQueue');
|
|
5
|
+
export const TrackPlayer = NitroModules.createHybridObject('TrackPlayer');
|
|
6
|
+
// Android-only: Android Auto Media Library
|
|
7
|
+
export const AndroidAutoMediaLibrary = Platform.OS === 'android'
|
|
8
|
+
? NitroModules.createHybridObject('AndroidAutoMediaLibrary')
|
|
9
|
+
: null;
|
|
10
|
+
// Android-only: Audio Devices
|
|
11
|
+
export const AudioDevices = Platform.OS === 'android'
|
|
12
|
+
? NitroModules.createHybridObject('AudioDevices')
|
|
13
|
+
: null;
|
|
14
|
+
// iOS-only: Audio Route Picker
|
|
15
|
+
export const AudioRoutePicker = Platform.OS === 'ios'
|
|
16
|
+
? NitroModules.createHybridObject('AudioRoutePicker')
|
|
17
|
+
: null;
|
|
18
|
+
// Export hooks
|
|
19
|
+
export * from './hooks';
|
|
20
|
+
// Export types
|
|
21
|
+
export * from './types/PlayerQueue';
|
|
22
|
+
export * from './types/AndroidAutoMediaLibrary';
|
|
23
|
+
// Export utilities
|
|
24
|
+
export { AndroidAutoMediaLibraryHelper } from './utils/androidAutoMediaLibrary';
|