react-native-nitro-player 0.3.0-alpha.5 → 0.3.0-alpha.7
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/README.md +699 -1
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridTrackPlayer.kt +4 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/core/TrackPlayerCore.kt +44 -7
- package/ios/HybridTrackPlayer.swift +6 -0
- package/ios/core/TrackPlayerCore.swift +214 -41
- 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 +15 -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 +42 -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/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp +5 -0
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.hpp +1 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt +4 -0
- package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.hpp +8 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec.swift +1 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec_cxx.swift +12 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp +1 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.hpp +1 -0
- package/package.json +10 -9
- package/src/specs/TrackPlayer.nitro.ts +1 -0
|
@@ -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,15 @@
|
|
|
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 type { RepeatMode } from './specs/TrackPlayer.nitro';
|
|
15
|
+
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';
|
|
@@ -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,42 @@
|
|
|
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 type RepeatMode = 'off' | 'Playlist' | 'track';
|
|
22
|
+
export interface TrackPlayer extends HybridObject<{
|
|
23
|
+
android: 'kotlin';
|
|
24
|
+
ios: 'swift';
|
|
25
|
+
}> {
|
|
26
|
+
play(): void;
|
|
27
|
+
pause(): void;
|
|
28
|
+
playSong(songId: string, fromPlaylist?: string): void;
|
|
29
|
+
skipToNext(): void;
|
|
30
|
+
skipToPrevious(): void;
|
|
31
|
+
seek(position: number): void;
|
|
32
|
+
getState(): PlayerState;
|
|
33
|
+
setRepeatMode(mode: RepeatMode): boolean;
|
|
34
|
+
configure(config: PlayerConfig): void;
|
|
35
|
+
onChangeTrack(callback: (track: TrackItem, reason?: Reason) => void): void;
|
|
36
|
+
onPlaybackStateChange(callback: (state: TrackPlayerState, reason?: Reason) => void): void;
|
|
37
|
+
onSeek(callback: (position: number, totalDuration: number) => void): void;
|
|
38
|
+
onPlaybackProgressChange(callback: (position: number, totalDuration: number, isManuallySeeked?: boolean) => void): void;
|
|
39
|
+
onAndroidAutoConnectionChange(callback: (connected: boolean) => void): void;
|
|
40
|
+
isAndroidAutoConnected(): boolean;
|
|
41
|
+
setVolume(volume: number): boolean;
|
|
42
|
+
}
|
|
@@ -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
|
+
};
|
|
@@ -142,5 +142,10 @@ namespace margelo::nitro::nitroplayer {
|
|
|
142
142
|
auto __result = method(_javaPart);
|
|
143
143
|
return static_cast<bool>(__result);
|
|
144
144
|
}
|
|
145
|
+
bool JHybridTrackPlayerSpec::setVolume(double volume) {
|
|
146
|
+
static const auto method = javaClassStatic()->getMethod<jboolean(double /* volume */)>("setVolume");
|
|
147
|
+
auto __result = method(_javaPart, volume);
|
|
148
|
+
return static_cast<bool>(__result);
|
|
149
|
+
}
|
|
145
150
|
|
|
146
151
|
} // namespace margelo::nitro::nitroplayer
|
|
@@ -69,6 +69,7 @@ namespace margelo::nitro::nitroplayer {
|
|
|
69
69
|
void onPlaybackProgressChange(const std::function<void(double /* position */, double /* totalDuration */, std::optional<bool> /* isManuallySeeked */)>& callback) override;
|
|
70
70
|
void onAndroidAutoConnectionChange(const std::function<void(bool /* connected */)>& callback) override;
|
|
71
71
|
bool isAndroidAutoConnected() override;
|
|
72
|
+
bool setVolume(double volume) override;
|
|
72
73
|
|
|
73
74
|
private:
|
|
74
75
|
friend HybridBase;
|
package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt
CHANGED
|
@@ -129,6 +129,10 @@ abstract class HybridTrackPlayerSpec: HybridObject() {
|
|
|
129
129
|
@DoNotStrip
|
|
130
130
|
@Keep
|
|
131
131
|
abstract fun isAndroidAutoConnected(): Boolean
|
|
132
|
+
|
|
133
|
+
@DoNotStrip
|
|
134
|
+
@Keep
|
|
135
|
+
abstract fun setVolume(volume: Double): Boolean
|
|
132
136
|
|
|
133
137
|
private external fun initHybrid(): HybridData
|
|
134
138
|
|
|
@@ -177,6 +177,14 @@ namespace margelo::nitro::nitroplayer {
|
|
|
177
177
|
auto __value = std::move(__result.value());
|
|
178
178
|
return __value;
|
|
179
179
|
}
|
|
180
|
+
inline bool setVolume(double volume) override {
|
|
181
|
+
auto __result = _swiftPart.setVolume(std::forward<decltype(volume)>(volume));
|
|
182
|
+
if (__result.hasError()) [[unlikely]] {
|
|
183
|
+
std::rethrow_exception(__result.error());
|
|
184
|
+
}
|
|
185
|
+
auto __value = std::move(__result.value());
|
|
186
|
+
return __value;
|
|
187
|
+
}
|
|
180
188
|
|
|
181
189
|
private:
|
|
182
190
|
NitroPlayer::HybridTrackPlayerSpec_cxx _swiftPart;
|
|
@@ -29,6 +29,7 @@ public protocol HybridTrackPlayerSpec_protocol: HybridObject {
|
|
|
29
29
|
func onPlaybackProgressChange(callback: @escaping (_ position: Double, _ totalDuration: Double, _ isManuallySeeked: Bool?) -> Void) throws -> Void
|
|
30
30
|
func onAndroidAutoConnectionChange(callback: @escaping (_ connected: Bool) -> Void) throws -> Void
|
|
31
31
|
func isAndroidAutoConnected() throws -> Bool
|
|
32
|
+
func setVolume(volume: Double) throws -> Bool
|
|
32
33
|
}
|
|
33
34
|
|
|
34
35
|
public extension HybridTrackPlayerSpec_protocol {
|
|
@@ -334,4 +334,16 @@ open class HybridTrackPlayerSpec_cxx {
|
|
|
334
334
|
return bridge.create_Result_bool_(__exceptionPtr)
|
|
335
335
|
}
|
|
336
336
|
}
|
|
337
|
+
|
|
338
|
+
@inline(__always)
|
|
339
|
+
public final func setVolume(volume: Double) -> bridge.Result_bool_ {
|
|
340
|
+
do {
|
|
341
|
+
let __result = try self.__implementation.setVolume(volume: volume)
|
|
342
|
+
let __resultCpp = __result
|
|
343
|
+
return bridge.create_Result_bool_(__resultCpp)
|
|
344
|
+
} catch (let __error) {
|
|
345
|
+
let __exceptionPtr = __error.toCpp()
|
|
346
|
+
return bridge.create_Result_bool_(__exceptionPtr)
|
|
347
|
+
}
|
|
348
|
+
}
|
|
337
349
|
}
|
|
@@ -29,6 +29,7 @@ namespace margelo::nitro::nitroplayer {
|
|
|
29
29
|
prototype.registerHybridMethod("onPlaybackProgressChange", &HybridTrackPlayerSpec::onPlaybackProgressChange);
|
|
30
30
|
prototype.registerHybridMethod("onAndroidAutoConnectionChange", &HybridTrackPlayerSpec::onAndroidAutoConnectionChange);
|
|
31
31
|
prototype.registerHybridMethod("isAndroidAutoConnected", &HybridTrackPlayerSpec::isAndroidAutoConnected);
|
|
32
|
+
prototype.registerHybridMethod("setVolume", &HybridTrackPlayerSpec::setVolume);
|
|
32
33
|
});
|
|
33
34
|
}
|
|
34
35
|
|
|
@@ -82,6 +82,7 @@ namespace margelo::nitro::nitroplayer {
|
|
|
82
82
|
virtual void onPlaybackProgressChange(const std::function<void(double /* position */, double /* totalDuration */, std::optional<bool> /* isManuallySeeked */)>& callback) = 0;
|
|
83
83
|
virtual void onAndroidAutoConnectionChange(const std::function<void(bool /* connected */)>& callback) = 0;
|
|
84
84
|
virtual bool isAndroidAutoConnected() = 0;
|
|
85
|
+
virtual bool setVolume(double volume) = 0;
|
|
85
86
|
|
|
86
87
|
protected:
|
|
87
88
|
// Hybrid Setup
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-nitro-player",
|
|
3
|
-
"version": "0.3.0-alpha.
|
|
3
|
+
"version": "0.3.0-alpha.7",
|
|
4
4
|
"description": "react-native-nitro-player",
|
|
5
5
|
"main": "lib/index",
|
|
6
6
|
"module": "lib/index",
|
|
@@ -30,13 +30,14 @@
|
|
|
30
30
|
"scripts": {
|
|
31
31
|
"postinstall": "tsc || exit 0;",
|
|
32
32
|
"typecheck": "tsc --noEmit",
|
|
33
|
-
"clean": "rm -rf android/build node_modules/**/android/build lib nitrogen",
|
|
33
|
+
"clean": "rm -rf android/build node_modules/**/android/build lib nitrogen tsconfig.tsbuildinfo",
|
|
34
34
|
"lint": "eslint \"**/*.{js,ts,tsx}\" --fix",
|
|
35
35
|
"lint-ci": "eslint \"**/*.{js,ts,tsx}\" -f @jamesacarr/github-actions",
|
|
36
36
|
"typescript": "tsc",
|
|
37
|
-
"specs": "tsc
|
|
37
|
+
"specs": "tsc && nitrogen --logLevel=\"debug\"",
|
|
38
|
+
"copy-readme": "cp ../README.md README.md",
|
|
38
39
|
"release": "release-it",
|
|
39
|
-
"build": "bun run clean && bun run specs && bun run typescript"
|
|
40
|
+
"build": "bun run clean && bun run specs && bun run typescript && bun run copy-readme"
|
|
40
41
|
},
|
|
41
42
|
"keywords": [
|
|
42
43
|
"react-native",
|
|
@@ -44,14 +45,14 @@
|
|
|
44
45
|
],
|
|
45
46
|
"repository": {
|
|
46
47
|
"type": "git",
|
|
47
|
-
"url": "git+https://github.com/
|
|
48
|
+
"url": "git+https://github.com/riteshshukla04/react-native-nitro-player"
|
|
48
49
|
},
|
|
49
|
-
"author": "
|
|
50
|
+
"author": "Ritesh Shukla <riteshshukla2381@gmail.com> (https://github.com/riteshshukla04)",
|
|
50
51
|
"license": "MIT",
|
|
51
52
|
"bugs": {
|
|
52
|
-
"url": "https://github.com/
|
|
53
|
+
"url": "https://github.com/riteshshukla04/react-native-nitro-player/issues"
|
|
53
54
|
},
|
|
54
|
-
"homepage": "https://github.com/
|
|
55
|
+
"homepage": "https://github.com/riteshshukla04/react-native-nitro-player#readme",
|
|
55
56
|
"publishConfig": {
|
|
56
57
|
"registry": "https://registry.npmjs.org/"
|
|
57
58
|
},
|
|
@@ -124,7 +125,7 @@
|
|
|
124
125
|
"release": true
|
|
125
126
|
},
|
|
126
127
|
"hooks": {
|
|
127
|
-
"
|
|
128
|
+
"before:release": "bun run clean && bun run specs && bun run typescript && bun run copy-readme"
|
|
128
129
|
},
|
|
129
130
|
"plugins": {
|
|
130
131
|
"@release-it/bumper": {
|