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,21 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
/**
|
|
3
|
+
* Android Auto Media Library Manager
|
|
4
|
+
* Android-only HybridObject for managing Android Auto media browser structure
|
|
5
|
+
*/
|
|
6
|
+
export interface AndroidAutoMediaLibrary extends HybridObject<{
|
|
7
|
+
android: 'kotlin';
|
|
8
|
+
}> {
|
|
9
|
+
/**
|
|
10
|
+
* Set the Android Auto media library structure
|
|
11
|
+
* This defines what folders and playlists appear in Android Auto
|
|
12
|
+
*
|
|
13
|
+
* @param libraryJson - JSON string of the MediaLibrary structure
|
|
14
|
+
*/
|
|
15
|
+
setMediaLibrary(libraryJson: string): void;
|
|
16
|
+
/**
|
|
17
|
+
* Clear the Android Auto media library
|
|
18
|
+
* Falls back to showing all playlists
|
|
19
|
+
*/
|
|
20
|
+
clearMediaLibrary(): void;
|
|
21
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
export type TAudioDevice = {
|
|
3
|
+
id: number;
|
|
4
|
+
name: string;
|
|
5
|
+
type: number;
|
|
6
|
+
isActive: boolean;
|
|
7
|
+
};
|
|
8
|
+
export interface AudioDevices extends HybridObject<{
|
|
9
|
+
android: 'kotlin';
|
|
10
|
+
}> {
|
|
11
|
+
/**
|
|
12
|
+
* Get the list of audio devices
|
|
13
|
+
*
|
|
14
|
+
* @returns The list of audio devices
|
|
15
|
+
*/
|
|
16
|
+
getAudioDevices(): TAudioDevice[];
|
|
17
|
+
/**
|
|
18
|
+
* Set the audio device
|
|
19
|
+
*
|
|
20
|
+
* @param deviceId - The ID of the audio device
|
|
21
|
+
* @returns True if the audio device was set successfully, false otherwise
|
|
22
|
+
*/
|
|
23
|
+
setAudioDevice(deviceId: number): boolean;
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
export interface AudioRoutePicker extends HybridObject<{
|
|
3
|
+
ios: 'swift';
|
|
4
|
+
}> {
|
|
5
|
+
/**
|
|
6
|
+
* Show the audio route picker view (iOS only)
|
|
7
|
+
* This presents a native AVRoutePickerView for selecting audio output devices like AirPlay
|
|
8
|
+
*/
|
|
9
|
+
showRoutePicker(): void;
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
import type { QueueOperation, Reason, TrackItem, TrackPlayerState, PlayerState, PlayerConfig, Playlist } from '../types/PlayerQueue';
|
|
3
|
+
export interface PlayerQueue extends HybridObject<{
|
|
4
|
+
android: 'kotlin';
|
|
5
|
+
ios: 'swift';
|
|
6
|
+
}> {
|
|
7
|
+
createPlaylist(name: string, description?: string, artwork?: string): string;
|
|
8
|
+
deletePlaylist(playlistId: string): void;
|
|
9
|
+
updatePlaylist(playlistId: string, name?: string, description?: string, artwork?: string): void;
|
|
10
|
+
getPlaylist(playlistId: string): Playlist | null;
|
|
11
|
+
getAllPlaylists(): Playlist[];
|
|
12
|
+
addTrackToPlaylist(playlistId: string, track: TrackItem, index?: number): void;
|
|
13
|
+
addTracksToPlaylist(playlistId: string, tracks: TrackItem[], index?: number): void;
|
|
14
|
+
removeTrackFromPlaylist(playlistId: string, trackId: string): void;
|
|
15
|
+
reorderTrackInPlaylist(playlistId: string, trackId: string, newIndex: number): void;
|
|
16
|
+
loadPlaylist(playlistId: string): void;
|
|
17
|
+
getCurrentPlaylistId(): string | null;
|
|
18
|
+
onPlaylistsChanged(callback: (playlists: Playlist[], operation?: QueueOperation) => void): void;
|
|
19
|
+
onPlaylistChanged(callback: (playlistId: string, playlist: Playlist, operation?: QueueOperation) => void): void;
|
|
20
|
+
}
|
|
21
|
+
export interface TrackPlayer extends HybridObject<{
|
|
22
|
+
android: 'kotlin';
|
|
23
|
+
ios: 'swift';
|
|
24
|
+
}> {
|
|
25
|
+
play(): void;
|
|
26
|
+
pause(): void;
|
|
27
|
+
playSong(songId: string, fromPlaylist?: string): void;
|
|
28
|
+
skipToNext(): void;
|
|
29
|
+
skipToPrevious(): void;
|
|
30
|
+
seek(position: number): void;
|
|
31
|
+
getState(): PlayerState;
|
|
32
|
+
configure(config: PlayerConfig): void;
|
|
33
|
+
onChangeTrack(callback: (track: TrackItem, reason?: Reason) => void): void;
|
|
34
|
+
onPlaybackStateChange(callback: (state: TrackPlayerState, reason?: Reason) => void): void;
|
|
35
|
+
onSeek(callback: (position: number, totalDuration: number) => void): void;
|
|
36
|
+
onPlaybackProgressChange(callback: (position: number, totalDuration: number, isManuallySeeked?: boolean) => void): void;
|
|
37
|
+
onAndroidAutoConnectionChange(callback: (connected: boolean) => void): void;
|
|
38
|
+
isAndroidAutoConnected(): boolean;
|
|
39
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Layout type for the Android Auto media browser
|
|
3
|
+
*/
|
|
4
|
+
export type LayoutType = 'grid' | 'list';
|
|
5
|
+
/**
|
|
6
|
+
* Media type for different kinds of content
|
|
7
|
+
*/
|
|
8
|
+
export type MediaType = 'folder' | 'audio' | 'playlist';
|
|
9
|
+
/**
|
|
10
|
+
* Media item that can be displayed in Android Auto
|
|
11
|
+
*/
|
|
12
|
+
export interface MediaItem {
|
|
13
|
+
/** Unique identifier for the media item */
|
|
14
|
+
id: string;
|
|
15
|
+
/** Display title */
|
|
16
|
+
title: string;
|
|
17
|
+
/** Optional subtitle/description */
|
|
18
|
+
subtitle?: string;
|
|
19
|
+
/** Optional icon/artwork URL */
|
|
20
|
+
iconUrl?: string;
|
|
21
|
+
/** Whether this item can be played directly */
|
|
22
|
+
isPlayable: boolean;
|
|
23
|
+
/** Media type */
|
|
24
|
+
mediaType: MediaType;
|
|
25
|
+
/** Reference to playlist ID (for playlist items) - will load tracks from this playlist */
|
|
26
|
+
playlistId?: string;
|
|
27
|
+
/** Child items for browsable folders */
|
|
28
|
+
children?: MediaItem[];
|
|
29
|
+
/** Layout type for folder items (overrides library default) */
|
|
30
|
+
layoutType?: LayoutType;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Media library structure for Android Auto
|
|
34
|
+
*/
|
|
35
|
+
export interface MediaLibrary {
|
|
36
|
+
/** Layout type for the media browser (applies to all folders by default) */
|
|
37
|
+
layoutType: LayoutType;
|
|
38
|
+
/** Root level media items */
|
|
39
|
+
rootItems: MediaItem[];
|
|
40
|
+
/** Optional app name to display */
|
|
41
|
+
appName?: string;
|
|
42
|
+
/** Optional app icon URL */
|
|
43
|
+
appIconUrl?: string;
|
|
44
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export interface TrackItem {
|
|
2
|
+
id: string;
|
|
3
|
+
title: string;
|
|
4
|
+
artist: string;
|
|
5
|
+
album: string;
|
|
6
|
+
duration: number;
|
|
7
|
+
url: string;
|
|
8
|
+
artwork?: string | null;
|
|
9
|
+
}
|
|
10
|
+
export interface Playlist {
|
|
11
|
+
id: string;
|
|
12
|
+
name: string;
|
|
13
|
+
description?: string | null;
|
|
14
|
+
artwork?: string | null;
|
|
15
|
+
tracks: TrackItem[];
|
|
16
|
+
}
|
|
17
|
+
export type QueueOperation = 'add' | 'remove' | 'clear' | 'update';
|
|
18
|
+
export type TrackPlayerState = 'playing' | 'paused' | 'stopped';
|
|
19
|
+
export type Reason = 'user_action' | 'skip' | 'end' | 'error';
|
|
20
|
+
export interface PlayerState {
|
|
21
|
+
currentTrack: TrackItem | null;
|
|
22
|
+
currentPosition: number;
|
|
23
|
+
totalDuration: number;
|
|
24
|
+
currentState: TrackPlayerState;
|
|
25
|
+
currentPlaylistId: string | null;
|
|
26
|
+
currentIndex: number;
|
|
27
|
+
}
|
|
28
|
+
export interface PlayerConfig {
|
|
29
|
+
androidAutoEnabled?: boolean;
|
|
30
|
+
carPlayEnabled?: boolean;
|
|
31
|
+
showInNotification?: boolean;
|
|
32
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { MediaLibrary } from '../types/AndroidAutoMediaLibrary';
|
|
2
|
+
/**
|
|
3
|
+
* Helper utilities for Android Auto Media Library
|
|
4
|
+
* Android-only functionality
|
|
5
|
+
*/
|
|
6
|
+
export declare const AndroidAutoMediaLibraryHelper: {
|
|
7
|
+
/**
|
|
8
|
+
* Set the Android Auto media library structure
|
|
9
|
+
* This defines what folders and playlists appear in Android Auto
|
|
10
|
+
*
|
|
11
|
+
* @param library - The media library structure
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```ts
|
|
15
|
+
* AndroidAutoMediaLibraryHelper.set({
|
|
16
|
+
* layoutType: 'grid',
|
|
17
|
+
* rootItems: [
|
|
18
|
+
* {
|
|
19
|
+
* id: 'my_music',
|
|
20
|
+
* title: 'My Music',
|
|
21
|
+
* mediaType: 'folder',
|
|
22
|
+
* isPlayable: false,
|
|
23
|
+
* children: [
|
|
24
|
+
* {
|
|
25
|
+
* id: 'favorites',
|
|
26
|
+
* title: 'Favorites',
|
|
27
|
+
* mediaType: 'playlist',
|
|
28
|
+
* playlistId: 'favorites-playlist-id', // References a playlist created with PlayerQueue
|
|
29
|
+
* isPlayable: false,
|
|
30
|
+
* },
|
|
31
|
+
* ],
|
|
32
|
+
* },
|
|
33
|
+
* ],
|
|
34
|
+
* })
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
set: (library: MediaLibrary) => void;
|
|
38
|
+
/**
|
|
39
|
+
* Clear the Android Auto media library
|
|
40
|
+
* Falls back to showing all playlists
|
|
41
|
+
*/
|
|
42
|
+
clear: () => void;
|
|
43
|
+
/**
|
|
44
|
+
* Check if Android Auto Media Library is available (Android only)
|
|
45
|
+
*/
|
|
46
|
+
isAvailable: () => boolean;
|
|
47
|
+
};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { AndroidAutoMediaLibrary as AndroidAutoMediaLibraryModule } from '../index';
|
|
2
|
+
/**
|
|
3
|
+
* Helper utilities for Android Auto Media Library
|
|
4
|
+
* Android-only functionality
|
|
5
|
+
*/
|
|
6
|
+
export const AndroidAutoMediaLibraryHelper = {
|
|
7
|
+
/**
|
|
8
|
+
* Set the Android Auto media library structure
|
|
9
|
+
* This defines what folders and playlists appear in Android Auto
|
|
10
|
+
*
|
|
11
|
+
* @param library - The media library structure
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```ts
|
|
15
|
+
* AndroidAutoMediaLibraryHelper.set({
|
|
16
|
+
* layoutType: 'grid',
|
|
17
|
+
* rootItems: [
|
|
18
|
+
* {
|
|
19
|
+
* id: 'my_music',
|
|
20
|
+
* title: 'My Music',
|
|
21
|
+
* mediaType: 'folder',
|
|
22
|
+
* isPlayable: false,
|
|
23
|
+
* children: [
|
|
24
|
+
* {
|
|
25
|
+
* id: 'favorites',
|
|
26
|
+
* title: 'Favorites',
|
|
27
|
+
* mediaType: 'playlist',
|
|
28
|
+
* playlistId: 'favorites-playlist-id', // References a playlist created with PlayerQueue
|
|
29
|
+
* isPlayable: false,
|
|
30
|
+
* },
|
|
31
|
+
* ],
|
|
32
|
+
* },
|
|
33
|
+
* ],
|
|
34
|
+
* })
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
set: (library) => {
|
|
38
|
+
if (!AndroidAutoMediaLibraryModule) {
|
|
39
|
+
console.warn('AndroidAutoMediaLibrary is only available on Android');
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const json = JSON.stringify(library);
|
|
43
|
+
AndroidAutoMediaLibraryModule.setMediaLibrary(json);
|
|
44
|
+
},
|
|
45
|
+
/**
|
|
46
|
+
* Clear the Android Auto media library
|
|
47
|
+
* Falls back to showing all playlists
|
|
48
|
+
*/
|
|
49
|
+
clear: () => {
|
|
50
|
+
if (!AndroidAutoMediaLibraryModule) {
|
|
51
|
+
console.warn('AndroidAutoMediaLibrary is only available on Android');
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
AndroidAutoMediaLibraryModule.clearMediaLibrary();
|
|
55
|
+
},
|
|
56
|
+
/**
|
|
57
|
+
* Check if Android Auto Media Library is available (Android only)
|
|
58
|
+
*/
|
|
59
|
+
isAvailable: () => {
|
|
60
|
+
return AndroidAutoMediaLibraryModule !== null;
|
|
61
|
+
},
|
|
62
|
+
};
|
package/nitro.json
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://nitro.margelo.com/nitro.schema.json",
|
|
3
|
+
"cxxNamespace": ["nitroplayer"],
|
|
4
|
+
"ios": {
|
|
5
|
+
"iosModuleName": "NitroPlayer"
|
|
6
|
+
},
|
|
7
|
+
"android": {
|
|
8
|
+
"androidNamespace": ["nitroplayer"],
|
|
9
|
+
"androidCxxLibName": "NitroPlayer"
|
|
10
|
+
},
|
|
11
|
+
"autolinking": {
|
|
12
|
+
"PlayerQueue": {
|
|
13
|
+
"swift": "HybridPlayerQueue",
|
|
14
|
+
"kotlin": "HybridPlayerQueue"
|
|
15
|
+
},
|
|
16
|
+
"TrackPlayer": {
|
|
17
|
+
"swift": "HybridTrackPlayer",
|
|
18
|
+
"kotlin": "HybridTrackPlayer"
|
|
19
|
+
},
|
|
20
|
+
"AndroidAutoMediaLibrary": {
|
|
21
|
+
"kotlin": "HybridAndroidAutoMediaLibrary"
|
|
22
|
+
},
|
|
23
|
+
"AudioDevices": {
|
|
24
|
+
"kotlin": "HybridAudioDevices"
|
|
25
|
+
},
|
|
26
|
+
"AudioRoutePicker": {
|
|
27
|
+
"swift": "HybridAudioRoutePicker"
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
"ignorePaths": ["**/node_modules"]
|
|
31
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
** linguist-generated=true
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
#
|
|
2
|
+
# NitroPlayer+autolinking.cmake
|
|
3
|
+
# This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
# https://github.com/mrousavy/nitro
|
|
5
|
+
# Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
#
|
|
7
|
+
|
|
8
|
+
# This is a CMake file that adds all files generated by Nitrogen
|
|
9
|
+
# to the current CMake project.
|
|
10
|
+
#
|
|
11
|
+
# To use it, add this to your CMakeLists.txt:
|
|
12
|
+
# ```cmake
|
|
13
|
+
# include(${CMAKE_SOURCE_DIR}/../nitrogen/generated/android/NitroPlayer+autolinking.cmake)
|
|
14
|
+
# ```
|
|
15
|
+
|
|
16
|
+
# Define a flag to check if we are building properly
|
|
17
|
+
add_definitions(-DBUILDING_NITROPLAYER_WITH_GENERATED_CMAKE_PROJECT)
|
|
18
|
+
|
|
19
|
+
# Enable Raw Props parsing in react-native (for Nitro Views)
|
|
20
|
+
add_definitions(-DRN_SERIALIZABLE_STATE)
|
|
21
|
+
|
|
22
|
+
# Add all headers that were generated by Nitrogen
|
|
23
|
+
include_directories(
|
|
24
|
+
"../nitrogen/generated/shared/c++"
|
|
25
|
+
"../nitrogen/generated/android/c++"
|
|
26
|
+
"../nitrogen/generated/android/"
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# Add all .cpp sources that were generated by Nitrogen
|
|
30
|
+
target_sources(
|
|
31
|
+
# CMake project name (Android C++ library name)
|
|
32
|
+
NitroPlayer PRIVATE
|
|
33
|
+
# Autolinking Setup
|
|
34
|
+
../nitrogen/generated/android/NitroPlayerOnLoad.cpp
|
|
35
|
+
# Shared Nitrogen C++ sources
|
|
36
|
+
../nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.cpp
|
|
37
|
+
../nitrogen/generated/shared/c++/HybridAudioDevicesSpec.cpp
|
|
38
|
+
../nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.cpp
|
|
39
|
+
../nitrogen/generated/shared/c++/HybridPlayerQueueSpec.cpp
|
|
40
|
+
../nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp
|
|
41
|
+
# Android-specific Nitrogen C++ sources
|
|
42
|
+
../nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.cpp
|
|
43
|
+
../nitrogen/generated/android/c++/JHybridAudioDevicesSpec.cpp
|
|
44
|
+
../nitrogen/generated/android/c++/JHybridPlayerQueueSpec.cpp
|
|
45
|
+
../nitrogen/generated/android/c++/JVariant_NullType_Playlist.cpp
|
|
46
|
+
../nitrogen/generated/android/c++/JVariant_NullType_String.cpp
|
|
47
|
+
../nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp
|
|
48
|
+
../nitrogen/generated/android/c++/JVariant_NullType_TrackItem.cpp
|
|
49
|
+
)
|
|
50
|
+
|
|
51
|
+
# From node_modules/react-native/ReactAndroid/cmake-utils/folly-flags.cmake
|
|
52
|
+
# Used in node_modules/react-native/ReactAndroid/cmake-utils/ReactNative-application.cmake
|
|
53
|
+
target_compile_definitions(
|
|
54
|
+
NitroPlayer PRIVATE
|
|
55
|
+
-DFOLLY_NO_CONFIG=1
|
|
56
|
+
-DFOLLY_HAVE_CLOCK_GETTIME=1
|
|
57
|
+
-DFOLLY_USE_LIBCPP=1
|
|
58
|
+
-DFOLLY_CFG_NO_COROUTINES=1
|
|
59
|
+
-DFOLLY_MOBILE=1
|
|
60
|
+
-DFOLLY_HAVE_RECVMMSG=1
|
|
61
|
+
-DFOLLY_HAVE_PTHREAD=1
|
|
62
|
+
# Once we target android-23 above, we can comment
|
|
63
|
+
# the following line. NDK uses GNU style stderror_r() after API 23.
|
|
64
|
+
-DFOLLY_HAVE_XSI_STRERROR_R=1
|
|
65
|
+
)
|
|
66
|
+
|
|
67
|
+
# Add all libraries required by the generated specs
|
|
68
|
+
find_package(fbjni REQUIRED) # <-- Used for communication between Java <-> C++
|
|
69
|
+
find_package(ReactAndroid REQUIRED) # <-- Used to set up React Native bindings (e.g. CallInvoker/TurboModule)
|
|
70
|
+
find_package(react-native-nitro-modules REQUIRED) # <-- Used to create all HybridObjects and use the Nitro core library
|
|
71
|
+
|
|
72
|
+
# Link all libraries together
|
|
73
|
+
target_link_libraries(
|
|
74
|
+
NitroPlayer
|
|
75
|
+
fbjni::fbjni # <-- Facebook C++ JNI helpers
|
|
76
|
+
ReactAndroid::jsi # <-- RN: JSI
|
|
77
|
+
react-native-nitro-modules::NitroModules # <-- NitroModules Core :)
|
|
78
|
+
)
|
|
79
|
+
|
|
80
|
+
# Link react-native (different prefab between RN 0.75 and RN 0.76)
|
|
81
|
+
if(ReactAndroid_VERSION_MINOR GREATER_EQUAL 76)
|
|
82
|
+
target_link_libraries(
|
|
83
|
+
NitroPlayer
|
|
84
|
+
ReactAndroid::reactnative # <-- RN: Native Modules umbrella prefab
|
|
85
|
+
)
|
|
86
|
+
else()
|
|
87
|
+
target_link_libraries(
|
|
88
|
+
NitroPlayer
|
|
89
|
+
ReactAndroid::react_nativemodule_core # <-- RN: TurboModules Core
|
|
90
|
+
)
|
|
91
|
+
endif()
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// NitroPlayer+autolinking.gradle
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
/// This is a Gradle file that adds all files generated by Nitrogen
|
|
9
|
+
/// to the current Gradle project.
|
|
10
|
+
///
|
|
11
|
+
/// To use it, add this to your build.gradle:
|
|
12
|
+
/// ```gradle
|
|
13
|
+
/// apply from: '../nitrogen/generated/android/NitroPlayer+autolinking.gradle'
|
|
14
|
+
/// ```
|
|
15
|
+
|
|
16
|
+
logger.warn("[NitroModules] 🔥 NitroPlayer is boosted by nitro!")
|
|
17
|
+
|
|
18
|
+
android {
|
|
19
|
+
sourceSets {
|
|
20
|
+
main {
|
|
21
|
+
java.srcDirs += [
|
|
22
|
+
// Nitrogen files
|
|
23
|
+
"${project.projectDir}/../nitrogen/generated/android/kotlin"
|
|
24
|
+
]
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// NitroPlayerOnLoad.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#ifndef BUILDING_NITROPLAYER_WITH_GENERATED_CMAKE_PROJECT
|
|
9
|
+
#error NitroPlayerOnLoad.cpp is not being built with the autogenerated CMakeLists.txt project. Is a different CMakeLists.txt building this?
|
|
10
|
+
#endif
|
|
11
|
+
|
|
12
|
+
#include "NitroPlayerOnLoad.hpp"
|
|
13
|
+
|
|
14
|
+
#include <jni.h>
|
|
15
|
+
#include <fbjni/fbjni.h>
|
|
16
|
+
#include <NitroModules/HybridObjectRegistry.hpp>
|
|
17
|
+
|
|
18
|
+
#include "JHybridAndroidAutoMediaLibrarySpec.hpp"
|
|
19
|
+
#include "JHybridAudioDevicesSpec.hpp"
|
|
20
|
+
#include "JHybridPlayerQueueSpec.hpp"
|
|
21
|
+
#include "JFunc_void_std__vector_Playlist__std__optional_QueueOperation_.hpp"
|
|
22
|
+
#include "JFunc_void_std__string_Playlist_std__optional_QueueOperation_.hpp"
|
|
23
|
+
#include "JHybridTrackPlayerSpec.hpp"
|
|
24
|
+
#include "JFunc_void_TrackItem_std__optional_Reason_.hpp"
|
|
25
|
+
#include "JFunc_void_TrackPlayerState_std__optional_Reason_.hpp"
|
|
26
|
+
#include "JFunc_void_double_double.hpp"
|
|
27
|
+
#include "JFunc_void_double_double_std__optional_bool_.hpp"
|
|
28
|
+
#include "JFunc_void_bool.hpp"
|
|
29
|
+
#include <NitroModules/DefaultConstructableObject.hpp>
|
|
30
|
+
|
|
31
|
+
namespace margelo::nitro::nitroplayer {
|
|
32
|
+
|
|
33
|
+
int initialize(JavaVM* vm) {
|
|
34
|
+
using namespace margelo::nitro;
|
|
35
|
+
using namespace margelo::nitro::nitroplayer;
|
|
36
|
+
using namespace facebook;
|
|
37
|
+
|
|
38
|
+
return facebook::jni::initialize(vm, [] {
|
|
39
|
+
// Register native JNI methods
|
|
40
|
+
margelo::nitro::nitroplayer::JHybridAndroidAutoMediaLibrarySpec::registerNatives();
|
|
41
|
+
margelo::nitro::nitroplayer::JHybridAudioDevicesSpec::registerNatives();
|
|
42
|
+
margelo::nitro::nitroplayer::JHybridPlayerQueueSpec::registerNatives();
|
|
43
|
+
margelo::nitro::nitroplayer::JFunc_void_std__vector_Playlist__std__optional_QueueOperation__cxx::registerNatives();
|
|
44
|
+
margelo::nitro::nitroplayer::JFunc_void_std__string_Playlist_std__optional_QueueOperation__cxx::registerNatives();
|
|
45
|
+
margelo::nitro::nitroplayer::JHybridTrackPlayerSpec::registerNatives();
|
|
46
|
+
margelo::nitro::nitroplayer::JFunc_void_TrackItem_std__optional_Reason__cxx::registerNatives();
|
|
47
|
+
margelo::nitro::nitroplayer::JFunc_void_TrackPlayerState_std__optional_Reason__cxx::registerNatives();
|
|
48
|
+
margelo::nitro::nitroplayer::JFunc_void_double_double_cxx::registerNatives();
|
|
49
|
+
margelo::nitro::nitroplayer::JFunc_void_double_double_std__optional_bool__cxx::registerNatives();
|
|
50
|
+
margelo::nitro::nitroplayer::JFunc_void_bool_cxx::registerNatives();
|
|
51
|
+
|
|
52
|
+
// Register Nitro Hybrid Objects
|
|
53
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
54
|
+
"PlayerQueue",
|
|
55
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
56
|
+
static DefaultConstructableObject<JHybridPlayerQueueSpec::javaobject> object("com/margelo/nitro/nitroplayer/HybridPlayerQueue");
|
|
57
|
+
auto instance = object.create();
|
|
58
|
+
return instance->cthis()->shared();
|
|
59
|
+
}
|
|
60
|
+
);
|
|
61
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
62
|
+
"TrackPlayer",
|
|
63
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
64
|
+
static DefaultConstructableObject<JHybridTrackPlayerSpec::javaobject> object("com/margelo/nitro/nitroplayer/HybridTrackPlayer");
|
|
65
|
+
auto instance = object.create();
|
|
66
|
+
return instance->cthis()->shared();
|
|
67
|
+
}
|
|
68
|
+
);
|
|
69
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
70
|
+
"AndroidAutoMediaLibrary",
|
|
71
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
72
|
+
static DefaultConstructableObject<JHybridAndroidAutoMediaLibrarySpec::javaobject> object("com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrary");
|
|
73
|
+
auto instance = object.create();
|
|
74
|
+
return instance->cthis()->shared();
|
|
75
|
+
}
|
|
76
|
+
);
|
|
77
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
78
|
+
"AudioDevices",
|
|
79
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
80
|
+
static DefaultConstructableObject<JHybridAudioDevicesSpec::javaobject> object("com/margelo/nitro/nitroplayer/HybridAudioDevices");
|
|
81
|
+
auto instance = object.create();
|
|
82
|
+
return instance->cthis()->shared();
|
|
83
|
+
}
|
|
84
|
+
);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
} // namespace margelo::nitro::nitroplayer
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// NitroPlayerOnLoad.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include <jni.h>
|
|
9
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
10
|
+
|
|
11
|
+
namespace margelo::nitro::nitroplayer {
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Initializes the native (C++) part of NitroPlayer, and autolinks all Hybrid Objects.
|
|
15
|
+
* Call this in your `JNI_OnLoad` function (probably inside `cpp-adapter.cpp`).
|
|
16
|
+
* Example:
|
|
17
|
+
* ```cpp (cpp-adapter.cpp)
|
|
18
|
+
* JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* vm, void*) {
|
|
19
|
+
* return margelo::nitro::nitroplayer::initialize(vm);
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
int initialize(JavaVM* vm);
|
|
24
|
+
|
|
25
|
+
} // namespace margelo::nitro::nitroplayer
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JFunc_void_TrackItem_std__optional_Reason_.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <fbjni/fbjni.h>
|
|
11
|
+
#include <functional>
|
|
12
|
+
|
|
13
|
+
#include "TrackItem.hpp"
|
|
14
|
+
#include "Reason.hpp"
|
|
15
|
+
#include <optional>
|
|
16
|
+
#include <functional>
|
|
17
|
+
#include <NitroModules/JNICallable.hpp>
|
|
18
|
+
#include "JTrackItem.hpp"
|
|
19
|
+
#include <string>
|
|
20
|
+
#include <NitroModules/Null.hpp>
|
|
21
|
+
#include <variant>
|
|
22
|
+
#include "JVariant_NullType_String.hpp"
|
|
23
|
+
#include <NitroModules/JNull.hpp>
|
|
24
|
+
#include "JReason.hpp"
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::nitroplayer {
|
|
27
|
+
|
|
28
|
+
using namespace facebook;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Represents the Java/Kotlin callback `(track: TrackItem, reason: Reason?) -> Unit`.
|
|
32
|
+
* This can be passed around between C++ and Java/Kotlin.
|
|
33
|
+
*/
|
|
34
|
+
struct JFunc_void_TrackItem_std__optional_Reason_: public jni::JavaClass<JFunc_void_TrackItem_std__optional_Reason_> {
|
|
35
|
+
public:
|
|
36
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/nitroplayer/Func_void_TrackItem_std__optional_Reason_;";
|
|
37
|
+
|
|
38
|
+
public:
|
|
39
|
+
/**
|
|
40
|
+
* Invokes the function this `JFunc_void_TrackItem_std__optional_Reason_` instance holds through JNI.
|
|
41
|
+
*/
|
|
42
|
+
void invoke(const TrackItem& track, std::optional<Reason> reason) const {
|
|
43
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JTrackItem> /* track */, jni::alias_ref<JReason> /* reason */)>("invoke");
|
|
44
|
+
method(self(), JTrackItem::fromCpp(track), reason.has_value() ? JReason::fromCpp(reason.value()) : nullptr);
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* An implementation of Func_void_TrackItem_std__optional_Reason_ that is backed by a C++ implementation (using `std::function<...>`)
|
|
50
|
+
*/
|
|
51
|
+
class JFunc_void_TrackItem_std__optional_Reason__cxx final: public jni::HybridClass<JFunc_void_TrackItem_std__optional_Reason__cxx, JFunc_void_TrackItem_std__optional_Reason_> {
|
|
52
|
+
public:
|
|
53
|
+
static jni::local_ref<JFunc_void_TrackItem_std__optional_Reason_::javaobject> fromCpp(const std::function<void(const TrackItem& /* track */, std::optional<Reason> /* reason */)>& func) {
|
|
54
|
+
return JFunc_void_TrackItem_std__optional_Reason__cxx::newObjectCxxArgs(func);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public:
|
|
58
|
+
/**
|
|
59
|
+
* Invokes the C++ `std::function<...>` this `JFunc_void_TrackItem_std__optional_Reason__cxx` instance holds.
|
|
60
|
+
*/
|
|
61
|
+
void invoke_cxx(jni::alias_ref<JTrackItem> track, jni::alias_ref<JReason> reason) {
|
|
62
|
+
_func(track->toCpp(), reason != nullptr ? std::make_optional(reason->toCpp()) : std::nullopt);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
public:
|
|
66
|
+
[[nodiscard]]
|
|
67
|
+
inline const std::function<void(const TrackItem& /* track */, std::optional<Reason> /* reason */)>& getFunction() const {
|
|
68
|
+
return _func;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
public:
|
|
72
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/nitroplayer/Func_void_TrackItem_std__optional_Reason__cxx;";
|
|
73
|
+
static void registerNatives() {
|
|
74
|
+
registerHybrid({makeNativeMethod("invoke_cxx", JFunc_void_TrackItem_std__optional_Reason__cxx::invoke_cxx)});
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
private:
|
|
78
|
+
explicit JFunc_void_TrackItem_std__optional_Reason__cxx(const std::function<void(const TrackItem& /* track */, std::optional<Reason> /* reason */)>& func): _func(func) { }
|
|
79
|
+
|
|
80
|
+
private:
|
|
81
|
+
friend HybridBase;
|
|
82
|
+
std::function<void(const TrackItem& /* track */, std::optional<Reason> /* reason */)> _func;
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
} // namespace margelo::nitro::nitroplayer
|