react-native-nitro-player 0.3.0-alpha.9 → 0.4.1-alpha.0

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.
Files changed (262) hide show
  1. package/README.md +444 -4
  2. package/android/build.gradle +4 -1
  3. package/android/src/main/AndroidManifest.xml +16 -1
  4. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrary.kt +2 -0
  5. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAudioDevices.kt +8 -0
  6. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridDownloadManager.kt +225 -0
  7. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridEqualizer.kt +105 -0
  8. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridPlayerQueue.kt +6 -6
  9. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridTrackPlayer.kt +37 -12
  10. package/android/src/main/java/com/margelo/nitro/nitroplayer/core/TrackPlayerCore.kt +944 -213
  11. package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadDatabase.kt +475 -0
  12. package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadFileManager.kt +159 -0
  13. package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadManagerCore.kt +489 -0
  14. package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadWorker.kt +209 -0
  15. package/android/src/main/java/com/margelo/nitro/nitroplayer/equalizer/EqualizerCore.kt +486 -0
  16. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaBrowserService.kt +3 -1
  17. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaSessionManager.kt +14 -6
  18. package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/PlaylistManager.kt +27 -0
  19. package/ios/HybridDownloadManager.swift +226 -0
  20. package/ios/HybridEqualizer.swift +111 -0
  21. package/ios/HybridTrackPlayer.swift +36 -8
  22. package/ios/core/TrackPlayerCore.swift +996 -288
  23. package/ios/download/DownloadDatabase.swift +493 -0
  24. package/ios/download/DownloadFileManager.swift +241 -0
  25. package/ios/download/DownloadManagerCore.swift +923 -0
  26. package/ios/equalizer/EqualizerCore.swift +685 -0
  27. package/ios/media/MediaSessionManager.swift +40 -28
  28. package/ios/playlist/PlaylistManager.swift +40 -9
  29. package/ios/queue/HybridPlayerQueue.swift +33 -13
  30. package/lib/hooks/callbackManager.d.ts +18 -0
  31. package/lib/hooks/callbackManager.js +66 -0
  32. package/lib/hooks/downloadCallbackManager.d.ts +36 -0
  33. package/lib/hooks/downloadCallbackManager.js +108 -0
  34. package/lib/hooks/equalizerCallbackManager.d.ts +37 -0
  35. package/lib/hooks/equalizerCallbackManager.js +109 -0
  36. package/lib/hooks/index.d.ts +16 -0
  37. package/lib/hooks/index.js +10 -0
  38. package/lib/hooks/useActualQueue.d.ts +48 -0
  39. package/lib/hooks/useActualQueue.js +98 -0
  40. package/lib/hooks/useDownloadActions.d.ts +26 -0
  41. package/lib/hooks/useDownloadActions.js +117 -0
  42. package/lib/hooks/useDownloadProgress.d.ts +25 -0
  43. package/lib/hooks/useDownloadProgress.js +79 -0
  44. package/lib/hooks/useDownloadStorage.d.ts +19 -0
  45. package/lib/hooks/useDownloadStorage.js +60 -0
  46. package/lib/hooks/useDownloadedTracks.d.ts +25 -0
  47. package/lib/hooks/useDownloadedTracks.js +69 -0
  48. package/lib/hooks/useEqualizer.d.ts +25 -0
  49. package/lib/hooks/useEqualizer.js +124 -0
  50. package/lib/hooks/useEqualizerPresets.d.ts +22 -0
  51. package/lib/hooks/useEqualizerPresets.js +96 -0
  52. package/lib/hooks/useNowPlaying.js +32 -19
  53. package/lib/hooks/useOnChangeTrack.js +15 -12
  54. package/lib/hooks/useOnPlaybackProgressChange.js +2 -2
  55. package/lib/hooks/useOnPlaybackStateChange.js +16 -13
  56. package/lib/hooks/usePlaylist.d.ts +48 -0
  57. package/lib/hooks/usePlaylist.js +136 -0
  58. package/lib/index.d.ts +6 -0
  59. package/lib/index.js +6 -0
  60. package/lib/specs/DownloadManager.nitro.d.ts +152 -0
  61. package/lib/specs/DownloadManager.nitro.js +1 -0
  62. package/lib/specs/Equalizer.nitro.d.ts +43 -0
  63. package/lib/specs/Equalizer.nitro.js +1 -0
  64. package/lib/specs/TrackPlayer.nitro.d.ts +6 -2
  65. package/lib/types/DownloadTypes.d.ts +110 -0
  66. package/lib/types/DownloadTypes.js +1 -0
  67. package/lib/types/EqualizerTypes.d.ts +52 -0
  68. package/lib/types/EqualizerTypes.js +1 -0
  69. package/lib/types/PlayerQueue.d.ts +4 -0
  70. package/nitro.json +8 -0
  71. package/nitrogen/generated/android/NitroPlayer+autolinking.cmake +10 -1
  72. package/nitrogen/generated/android/NitroPlayerOnLoad.cpp +32 -2
  73. package/nitrogen/generated/android/c++/JCurrentPlayingType.hpp +65 -0
  74. package/nitrogen/generated/android/c++/JDownloadConfig.hpp +92 -0
  75. package/nitrogen/generated/android/c++/JDownloadError.hpp +71 -0
  76. package/nitrogen/generated/android/c++/JDownloadErrorReason.hpp +74 -0
  77. package/nitrogen/generated/android/c++/JDownloadProgress.hpp +79 -0
  78. package/nitrogen/generated/android/c++/JDownloadQueueStatus.hpp +81 -0
  79. package/nitrogen/generated/android/c++/JDownloadState.hpp +71 -0
  80. package/nitrogen/generated/android/c++/JDownloadStorageInfo.hpp +73 -0
  81. package/nitrogen/generated/android/c++/JDownloadTask.hpp +108 -0
  82. package/nitrogen/generated/android/c++/JDownloadedPlaylist.hpp +111 -0
  83. package/nitrogen/generated/android/c++/JDownloadedTrack.hpp +92 -0
  84. package/nitrogen/generated/android/c++/JEqualizerBand.hpp +69 -0
  85. package/nitrogen/generated/android/c++/JEqualizerPreset.hpp +78 -0
  86. package/nitrogen/generated/android/c++/JEqualizerState.hpp +91 -0
  87. package/nitrogen/generated/android/c++/JFunc_void_DownloadProgress.hpp +80 -0
  88. package/nitrogen/generated/android/c++/JFunc_void_DownloadedTrack.hpp +89 -0
  89. package/nitrogen/generated/android/c++/JFunc_void_TrackItem_std__optional_Reason_.hpp +2 -0
  90. package/nitrogen/generated/android/c++/JFunc_void_std__optional_std__variant_nitro__NullType__std__string__.hpp +81 -0
  91. package/nitrogen/generated/android/c++/JFunc_void_std__string_Playlist_std__optional_QueueOperation_.hpp +2 -0
  92. package/nitrogen/generated/android/c++/JFunc_void_std__string_std__string_DownloadState_std__optional_DownloadError_.hpp +83 -0
  93. package/nitrogen/generated/android/c++/JFunc_void_std__vector_EqualizerBand_.hpp +97 -0
  94. package/nitrogen/generated/android/c++/JFunc_void_std__vector_Playlist__std__optional_QueueOperation_.hpp +2 -0
  95. package/nitrogen/generated/android/c++/JGainRange.hpp +61 -0
  96. package/nitrogen/generated/android/c++/JHybridDownloadManagerSpec.cpp +470 -0
  97. package/nitrogen/generated/android/c++/JHybridDownloadManagerSpec.hpp +99 -0
  98. package/nitrogen/generated/android/c++/JHybridEqualizerSpec.cpp +204 -0
  99. package/nitrogen/generated/android/c++/JHybridEqualizerSpec.hpp +82 -0
  100. package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.cpp +2 -0
  101. package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp +117 -15
  102. package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.hpp +6 -2
  103. package/nitrogen/generated/android/c++/JPlaybackSource.hpp +62 -0
  104. package/nitrogen/generated/android/c++/JPlayerState.hpp +11 -3
  105. package/nitrogen/generated/android/c++/JPlaylist.hpp +2 -0
  106. package/nitrogen/generated/android/c++/JPresetType.hpp +59 -0
  107. package/nitrogen/generated/android/c++/JStorageLocation.hpp +59 -0
  108. package/nitrogen/generated/android/c++/JTrackItem.hpp +9 -3
  109. package/nitrogen/generated/android/c++/JTrackPlayerState.hpp +3 -3
  110. package/nitrogen/generated/android/c++/JVariant_NullType_Double.cpp +26 -0
  111. package/nitrogen/generated/android/c++/JVariant_NullType_Double.hpp +69 -0
  112. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadError.cpp +26 -0
  113. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadError.hpp +74 -0
  114. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadTask.cpp +26 -0
  115. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadTask.hpp +84 -0
  116. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedPlaylist.cpp +26 -0
  117. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedPlaylist.hpp +85 -0
  118. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedTrack.cpp +26 -0
  119. package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedTrack.hpp +80 -0
  120. package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.hpp +2 -0
  121. package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.hpp +2 -0
  122. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/CurrentPlayingType.kt +23 -0
  123. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadConfig.kt +59 -0
  124. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadError.kt +47 -0
  125. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadErrorReason.kt +26 -0
  126. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadProgress.kt +53 -0
  127. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadQueueStatus.kt +56 -0
  128. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadState.kt +25 -0
  129. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadStorageInfo.kt +50 -0
  130. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadTask.kt +65 -0
  131. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadedPlaylist.kt +53 -0
  132. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadedTrack.kt +56 -0
  133. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/EqualizerBand.kt +47 -0
  134. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/EqualizerPreset.kt +44 -0
  135. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/EqualizerState.kt +44 -0
  136. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_DownloadProgress.kt +80 -0
  137. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_DownloadedTrack.kt +80 -0
  138. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__optional_std__variant_nitro__NullType__std__string__.kt +80 -0
  139. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__string_std__string_DownloadState_std__optional_DownloadError_.kt +80 -0
  140. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__vector_EqualizerBand_.kt +80 -0
  141. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/GainRange.kt +41 -0
  142. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridDownloadManagerSpec.kt +210 -0
  143. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridEqualizerSpec.kt +141 -0
  144. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt +19 -2
  145. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlaybackSource.kt +22 -0
  146. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerState.kt +6 -3
  147. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PresetType.kt +21 -0
  148. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/StorageLocation.kt +21 -0
  149. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackItem.kt +7 -3
  150. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackPlayerState.kt +2 -2
  151. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_Double.kt +59 -0
  152. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadError.kt +59 -0
  153. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadTask.kt +59 -0
  154. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadedPlaylist.kt +59 -0
  155. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadedTrack.kt +59 -0
  156. package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.cpp +138 -8
  157. package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.hpp +1046 -121
  158. package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Umbrella.hpp +66 -0
  159. package/nitrogen/generated/ios/NitroPlayerAutolinking.mm +16 -0
  160. package/nitrogen/generated/ios/NitroPlayerAutolinking.swift +30 -0
  161. package/nitrogen/generated/ios/c++/HybridDownloadManagerSpecSwift.cpp +11 -0
  162. package/nitrogen/generated/ios/c++/HybridDownloadManagerSpecSwift.hpp +386 -0
  163. package/nitrogen/generated/ios/c++/HybridEqualizerSpecSwift.cpp +11 -0
  164. package/nitrogen/generated/ios/c++/HybridEqualizerSpecSwift.hpp +223 -0
  165. package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.hpp +1 -0
  166. package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.hpp +46 -6
  167. package/nitrogen/generated/ios/swift/CurrentPlayingType.swift +48 -0
  168. package/nitrogen/generated/ios/swift/DownloadConfig.swift +270 -0
  169. package/nitrogen/generated/ios/swift/DownloadError.swift +69 -0
  170. package/nitrogen/generated/ios/swift/DownloadErrorReason.swift +60 -0
  171. package/nitrogen/generated/ios/swift/DownloadProgress.swift +91 -0
  172. package/nitrogen/generated/ios/swift/DownloadQueueStatus.swift +102 -0
  173. package/nitrogen/generated/ios/swift/DownloadState.swift +56 -0
  174. package/nitrogen/generated/ios/swift/DownloadStorageInfo.swift +80 -0
  175. package/nitrogen/generated/ios/swift/DownloadTask.swift +315 -0
  176. package/nitrogen/generated/ios/swift/DownloadedPlaylist.swift +103 -0
  177. package/nitrogen/generated/ios/swift/DownloadedTrack.swift +147 -0
  178. package/nitrogen/generated/ios/swift/EqualizerBand.swift +69 -0
  179. package/nitrogen/generated/ios/swift/EqualizerPreset.swift +70 -0
  180. package/nitrogen/generated/ios/swift/EqualizerState.swift +115 -0
  181. package/nitrogen/generated/ios/swift/Func_void.swift +47 -0
  182. package/nitrogen/generated/ios/swift/Func_void_DownloadProgress.swift +47 -0
  183. package/nitrogen/generated/ios/swift/Func_void_DownloadStorageInfo.swift +47 -0
  184. package/nitrogen/generated/ios/swift/Func_void_DownloadedTrack.swift +47 -0
  185. package/nitrogen/generated/ios/swift/Func_void_PlayerState.swift +47 -0
  186. package/nitrogen/generated/ios/swift/Func_void_bool.swift +5 -5
  187. package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +47 -0
  188. package/nitrogen/generated/ios/swift/Func_void_std__optional_std__variant_nitro__NullType__std__string__.swift +66 -0
  189. package/nitrogen/generated/ios/swift/Func_void_std__string.swift +47 -0
  190. package/nitrogen/generated/ios/swift/Func_void_std__string_std__string_DownloadState_std__optional_DownloadError_.swift +47 -0
  191. package/nitrogen/generated/ios/swift/Func_void_std__vector_EqualizerBand_.swift +47 -0
  192. package/nitrogen/generated/ios/swift/Func_void_std__vector_TrackItem_.swift +47 -0
  193. package/nitrogen/generated/ios/swift/Func_void_std__vector_std__string_.swift +47 -0
  194. package/nitrogen/generated/ios/swift/GainRange.swift +47 -0
  195. package/nitrogen/generated/ios/swift/HybridDownloadManagerSpec.swift +90 -0
  196. package/nitrogen/generated/ios/swift/HybridDownloadManagerSpec_cxx.swift +705 -0
  197. package/nitrogen/generated/ios/swift/HybridEqualizerSpec.swift +73 -0
  198. package/nitrogen/generated/ios/swift/HybridEqualizerSpec_cxx.swift +396 -0
  199. package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec.swift +6 -2
  200. package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec_cxx.swift +105 -8
  201. package/nitrogen/generated/ios/swift/PlaybackSource.swift +44 -0
  202. package/nitrogen/generated/ios/swift/PlayerState.swift +13 -2
  203. package/nitrogen/generated/ios/swift/PresetType.swift +40 -0
  204. package/nitrogen/generated/ios/swift/StorageLocation.swift +40 -0
  205. package/nitrogen/generated/ios/swift/TrackItem.swift +31 -1
  206. package/nitrogen/generated/ios/swift/TrackPlayerState.swift +4 -4
  207. package/nitrogen/generated/ios/swift/Variant_NullType_Double.swift +18 -0
  208. package/nitrogen/generated/ios/swift/Variant_NullType_DownloadError.swift +18 -0
  209. package/nitrogen/generated/ios/swift/Variant_NullType_DownloadTask.swift +18 -0
  210. package/nitrogen/generated/ios/swift/Variant_NullType_DownloadedPlaylist.swift +18 -0
  211. package/nitrogen/generated/ios/swift/Variant_NullType_DownloadedTrack.swift +18 -0
  212. package/nitrogen/generated/shared/c++/CurrentPlayingType.hpp +84 -0
  213. package/nitrogen/generated/shared/c++/DownloadConfig.hpp +108 -0
  214. package/nitrogen/generated/shared/c++/DownloadError.hpp +89 -0
  215. package/nitrogen/generated/shared/c++/DownloadErrorReason.hpp +96 -0
  216. package/nitrogen/generated/shared/c++/DownloadProgress.hpp +97 -0
  217. package/nitrogen/generated/shared/c++/DownloadQueueStatus.hpp +99 -0
  218. package/nitrogen/generated/shared/c++/DownloadState.hpp +92 -0
  219. package/nitrogen/generated/shared/c++/DownloadStorageInfo.hpp +91 -0
  220. package/nitrogen/generated/shared/c++/DownloadTask.hpp +122 -0
  221. package/nitrogen/generated/shared/c++/DownloadedPlaylist.hpp +101 -0
  222. package/nitrogen/generated/shared/c++/DownloadedTrack.hpp +107 -0
  223. package/nitrogen/generated/shared/c++/EqualizerBand.hpp +87 -0
  224. package/nitrogen/generated/shared/c++/EqualizerPreset.hpp +86 -0
  225. package/nitrogen/generated/shared/c++/EqualizerState.hpp +89 -0
  226. package/nitrogen/generated/shared/c++/GainRange.hpp +79 -0
  227. package/nitrogen/generated/shared/c++/HybridDownloadManagerSpec.cpp +55 -0
  228. package/nitrogen/generated/shared/c++/HybridDownloadManagerSpec.hpp +134 -0
  229. package/nitrogen/generated/shared/c++/HybridEqualizerSpec.cpp +38 -0
  230. package/nitrogen/generated/shared/c++/HybridEqualizerSpec.hpp +95 -0
  231. package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp +4 -0
  232. package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.hpp +11 -5
  233. package/nitrogen/generated/shared/c++/PlaybackSource.hpp +80 -0
  234. package/nitrogen/generated/shared/c++/PlayerState.hpp +9 -2
  235. package/nitrogen/generated/shared/c++/PresetType.hpp +76 -0
  236. package/nitrogen/generated/shared/c++/StorageLocation.hpp +76 -0
  237. package/nitrogen/generated/shared/c++/TrackItem.hpp +7 -2
  238. package/nitrogen/generated/shared/c++/TrackPlayerState.hpp +5 -5
  239. package/package.json +1 -1
  240. package/src/hooks/callbackManager.ts +87 -0
  241. package/src/hooks/downloadCallbackManager.ts +149 -0
  242. package/src/hooks/equalizerCallbackManager.ts +138 -0
  243. package/src/hooks/index.ts +23 -0
  244. package/src/hooks/useActualQueue.ts +116 -0
  245. package/src/hooks/useDownloadActions.ts +179 -0
  246. package/src/hooks/useDownloadProgress.ts +126 -0
  247. package/src/hooks/useDownloadStorage.ts +84 -0
  248. package/src/hooks/useDownloadedTracks.ts +138 -0
  249. package/src/hooks/useEqualizer.ts +173 -0
  250. package/src/hooks/useEqualizerPresets.ts +140 -0
  251. package/src/hooks/useNowPlaying.ts +33 -20
  252. package/src/hooks/useOnChangeTrack.ts +15 -11
  253. package/src/hooks/useOnPlaybackProgressChange.ts +2 -2
  254. package/src/hooks/useOnPlaybackStateChange.ts +19 -15
  255. package/src/hooks/usePlaylist.ts +161 -0
  256. package/src/index.ts +12 -0
  257. package/src/specs/DownloadManager.nitro.ts +203 -0
  258. package/src/specs/Equalizer.nitro.ts +69 -0
  259. package/src/specs/TrackPlayer.nitro.ts +6 -2
  260. package/src/types/DownloadTypes.ts +135 -0
  261. package/src/types/EqualizerTypes.ts +72 -0
  262. package/src/types/PlayerQueue.ts +9 -0
@@ -0,0 +1,124 @@
1
+ import { useEffect, useState, useCallback, useRef } from 'react';
2
+ import { Equalizer } from '../index';
3
+ import { equalizerCallbackManager } from './equalizerCallbackManager';
4
+ const DEFAULT_BANDS = [
5
+ { index: 0, centerFrequency: 60, gainDb: 0, frequencyLabel: '60 Hz' },
6
+ { index: 1, centerFrequency: 230, gainDb: 0, frequencyLabel: '230 Hz' },
7
+ { index: 2, centerFrequency: 910, gainDb: 0, frequencyLabel: '910 Hz' },
8
+ { index: 3, centerFrequency: 3600, gainDb: 0, frequencyLabel: '3.6 kHz' },
9
+ { index: 4, centerFrequency: 14000, gainDb: 0, frequencyLabel: '14 kHz' },
10
+ ];
11
+ export function useEqualizer() {
12
+ const [isEnabled, setIsEnabledState] = useState(false);
13
+ const [bands, setBands] = useState(DEFAULT_BANDS);
14
+ const [currentPreset, setCurrentPreset] = useState(null);
15
+ const [isLoading, setIsLoading] = useState(true);
16
+ const [gainRange, setGainRange] = useState({ min: -12, max: 12 });
17
+ const isMounted = useRef(true);
18
+ // Load initial state
19
+ useEffect(() => {
20
+ isMounted.current = true;
21
+ const loadState = async () => {
22
+ try {
23
+ const state = Equalizer.getState();
24
+ if (isMounted.current) {
25
+ setIsEnabledState(state.enabled);
26
+ setBands(state.bands);
27
+ setCurrentPreset(state.currentPreset);
28
+ const range = Equalizer.getBandRange();
29
+ setGainRange({ min: range.min, max: range.max });
30
+ setIsLoading(false);
31
+ }
32
+ }
33
+ catch (error) {
34
+ console.error('[useEqualizer] Error loading state:', error);
35
+ if (isMounted.current) {
36
+ setIsLoading(false);
37
+ }
38
+ }
39
+ };
40
+ loadState();
41
+ return () => {
42
+ isMounted.current = false;
43
+ };
44
+ }, []);
45
+ // Subscribe to enabled changes
46
+ useEffect(() => {
47
+ const unsubscribe = equalizerCallbackManager.subscribeToEnabledChange((enabled) => {
48
+ if (isMounted.current) {
49
+ setIsEnabledState(enabled);
50
+ }
51
+ });
52
+ return unsubscribe;
53
+ }, []);
54
+ // Subscribe to band changes
55
+ useEffect(() => {
56
+ const unsubscribe = equalizerCallbackManager.subscribeToBandChange((newBands) => {
57
+ if (isMounted.current) {
58
+ setBands(newBands);
59
+ }
60
+ });
61
+ return unsubscribe;
62
+ }, []);
63
+ // Subscribe to preset changes
64
+ useEffect(() => {
65
+ const unsubscribe = equalizerCallbackManager.subscribeToPresetChange((presetName) => {
66
+ if (isMounted.current) {
67
+ setCurrentPreset(presetName);
68
+ }
69
+ });
70
+ return unsubscribe;
71
+ }, []);
72
+ const setEnabled = useCallback((enabled) => {
73
+ try {
74
+ return Equalizer.setEnabled(enabled);
75
+ }
76
+ catch (error) {
77
+ console.error('[useEqualizer] Error setting enabled:', error);
78
+ return false;
79
+ }
80
+ }, []);
81
+ const setBandGain = useCallback((bandIndex, gainDb) => {
82
+ // Optimistic update
83
+ setBands((prevBands) => prevBands.map((b) => (b.index === bandIndex ? { ...b, gainDb } : b)));
84
+ try {
85
+ return Equalizer.setBandGain(bandIndex, gainDb);
86
+ }
87
+ catch (error) {
88
+ console.error('[useEqualizer] Error setting band gain:', error);
89
+ return false;
90
+ }
91
+ }, []);
92
+ const setAllBandGains = useCallback((gains) => {
93
+ // Optimistic update
94
+ setBands((prevBands) => prevBands.map((b, i) => ({ ...b, gainDb: gains[i] ?? b.gainDb })));
95
+ try {
96
+ return Equalizer.setAllBandGains(gains);
97
+ }
98
+ catch (error) {
99
+ console.error('[useEqualizer] Error setting all band gains:', error);
100
+ return false;
101
+ }
102
+ }, []);
103
+ const reset = useCallback(() => {
104
+ // Optimistic update
105
+ setBands((prevBands) => prevBands.map((b) => ({ ...b, gainDb: 0 })));
106
+ try {
107
+ Equalizer.reset();
108
+ }
109
+ catch (error) {
110
+ console.error('[useEqualizer] Error resetting equalizer:', error);
111
+ }
112
+ }, []);
113
+ return {
114
+ isEnabled,
115
+ bands,
116
+ currentPreset,
117
+ setEnabled,
118
+ setBandGain,
119
+ setAllBandGains,
120
+ reset,
121
+ isLoading,
122
+ gainRange,
123
+ };
124
+ }
@@ -0,0 +1,22 @@
1
+ import type { EqualizerPreset } from '../types/EqualizerTypes';
2
+ export interface UseEqualizerPresetsResult {
3
+ /** All available presets */
4
+ presets: EqualizerPreset[];
5
+ /** Built-in presets only */
6
+ builtInPresets: EqualizerPreset[];
7
+ /** Custom user presets */
8
+ customPresets: EqualizerPreset[];
9
+ /** Apply a preset by name */
10
+ applyPreset: (name: string) => boolean;
11
+ /** Save current settings as custom preset */
12
+ saveCustomPreset: (name: string) => boolean;
13
+ /** Delete a custom preset */
14
+ deleteCustomPreset: (name: string) => boolean;
15
+ /** Currently applied preset name */
16
+ currentPreset: string | null;
17
+ /** Whether presets are loading */
18
+ isLoading: boolean;
19
+ /** Refresh presets from native */
20
+ refreshPresets: () => void;
21
+ }
22
+ export declare function useEqualizerPresets(): UseEqualizerPresetsResult;
@@ -0,0 +1,96 @@
1
+ import { useEffect, useState, useCallback, useRef } from 'react';
2
+ import { Equalizer } from '../index';
3
+ import { equalizerCallbackManager } from './equalizerCallbackManager';
4
+ export function useEqualizerPresets() {
5
+ const [presets, setPresets] = useState([]);
6
+ const [builtInPresets, setBuiltInPresets] = useState([]);
7
+ const [customPresets, setCustomPresets] = useState([]);
8
+ const [currentPreset, setCurrentPreset] = useState(null);
9
+ const [isLoading, setIsLoading] = useState(true);
10
+ const isMounted = useRef(true);
11
+ const refreshPresets = useCallback(() => {
12
+ try {
13
+ const allPresets = Equalizer.getPresets();
14
+ const builtIn = Equalizer.getBuiltInPresets();
15
+ const custom = Equalizer.getCustomPresets();
16
+ const current = Equalizer.getCurrentPresetName();
17
+ if (isMounted.current) {
18
+ setPresets(allPresets);
19
+ setBuiltInPresets(builtIn);
20
+ setCustomPresets(custom);
21
+ setCurrentPreset(current);
22
+ }
23
+ }
24
+ catch (error) {
25
+ console.error('[useEqualizerPresets] Error refreshing presets:', error);
26
+ }
27
+ }, []);
28
+ // Load initial presets
29
+ useEffect(() => {
30
+ isMounted.current = true;
31
+ refreshPresets();
32
+ setIsLoading(false);
33
+ return () => {
34
+ isMounted.current = false;
35
+ };
36
+ }, [refreshPresets]);
37
+ // Subscribe to preset changes
38
+ useEffect(() => {
39
+ const unsubscribe = equalizerCallbackManager.subscribeToPresetChange((presetName) => {
40
+ if (isMounted.current) {
41
+ setCurrentPreset(presetName);
42
+ }
43
+ });
44
+ return unsubscribe;
45
+ }, []);
46
+ const applyPreset = useCallback((name) => {
47
+ try {
48
+ const success = Equalizer.applyPreset(name);
49
+ if (success) {
50
+ setCurrentPreset(name);
51
+ }
52
+ return success;
53
+ }
54
+ catch (error) {
55
+ console.error('[useEqualizerPresets] Error applying preset:', error);
56
+ return false;
57
+ }
58
+ }, []);
59
+ const saveCustomPreset = useCallback((name) => {
60
+ try {
61
+ const success = Equalizer.saveCustomPreset(name);
62
+ if (success) {
63
+ refreshPresets();
64
+ }
65
+ return success;
66
+ }
67
+ catch (error) {
68
+ console.error('[useEqualizerPresets] Error saving custom preset:', error);
69
+ return false;
70
+ }
71
+ }, [refreshPresets]);
72
+ const deleteCustomPreset = useCallback((name) => {
73
+ try {
74
+ const success = Equalizer.deleteCustomPreset(name);
75
+ if (success) {
76
+ refreshPresets();
77
+ }
78
+ return success;
79
+ }
80
+ catch (error) {
81
+ console.error('[useEqualizerPresets] Error deleting custom preset:', error);
82
+ return false;
83
+ }
84
+ }, [refreshPresets]);
85
+ return {
86
+ presets,
87
+ builtInPresets,
88
+ customPresets,
89
+ applyPreset,
90
+ saveCustomPreset,
91
+ deleteCustomPreset,
92
+ currentPreset,
93
+ isLoading,
94
+ refreshPresets,
95
+ };
96
+ }
@@ -8,6 +8,7 @@ const DEFAULT_STATE = {
8
8
  currentState: 'stopped',
9
9
  currentPlaylistId: null,
10
10
  currentIndex: -1,
11
+ currentPlayingType: 'not-playing',
11
12
  };
12
13
  /**
13
14
  * Hook to get the current player state (same as TrackPlayer.getState())
@@ -46,12 +47,14 @@ const DEFAULT_STATE = {
46
47
  export function useNowPlaying() {
47
48
  const [state, setState] = useState(DEFAULT_STATE);
48
49
  const isMounted = useRef(true);
49
- const updateState = useCallback(() => {
50
+ const fetchFullState = useCallback(async () => {
50
51
  if (!isMounted.current)
51
52
  return;
52
53
  try {
53
- const newState = TrackPlayer.getState();
54
- setState(newState);
54
+ const newState = await TrackPlayer.getState();
55
+ if (isMounted.current) {
56
+ setState(newState);
57
+ }
55
58
  }
56
59
  catch (error) {
57
60
  console.error('[useNowPlaying] Error updating player state:', error);
@@ -60,28 +63,38 @@ export function useNowPlaying() {
60
63
  // Initialize with current state
61
64
  useEffect(() => {
62
65
  isMounted.current = true;
63
- updateState();
66
+ fetchFullState();
64
67
  return () => {
65
68
  isMounted.current = false;
66
69
  };
67
- }, [updateState]);
68
- // Subscribe to track changes
70
+ }, [fetchFullState]);
71
+ // Subscribe to track changes — full refresh
69
72
  useEffect(() => {
70
- const unsubscribe = callbackManager.subscribeToTrackChange(() => {
71
- updateState();
73
+ return callbackManager.subscribeToTrackChange(() => {
74
+ fetchFullState();
72
75
  });
73
- return () => {
74
- unsubscribe();
75
- };
76
- }, [updateState]);
77
- // Subscribe to playback state changes
76
+ }, [fetchFullState]);
77
+ // Subscribe to playback state changes — full refresh
78
78
  useEffect(() => {
79
- const unsubscribe = callbackManager.subscribeToPlaybackState(() => {
80
- updateState();
79
+ return callbackManager.subscribeToPlaybackState(() => {
80
+ fetchFullState();
81
81
  });
82
- return () => {
83
- unsubscribe();
84
- };
85
- }, [updateState]);
82
+ }, [fetchFullState]);
83
+ // Subscribe to progress changes — lightweight position/duration update
84
+ useEffect(() => {
85
+ return callbackManager.subscribeToPlaybackProgressChange((currentPosition, totalDuration) => {
86
+ if (!isMounted.current)
87
+ return;
88
+ setState((prev) => ({ ...prev, currentPosition, totalDuration }));
89
+ });
90
+ }, []);
91
+ // Subscribe to seek events — lightweight position/duration update
92
+ useEffect(() => {
93
+ return callbackManager.subscribeToSeek((currentPosition, totalDuration) => {
94
+ if (!isMounted.current)
95
+ return;
96
+ setState((prev) => ({ ...prev, currentPosition, totalDuration }));
97
+ });
98
+ }, []);
86
99
  return state;
87
100
  }
@@ -38,20 +38,23 @@ export function useOnChangeTrack() {
38
38
  // Initialize with current track from the player
39
39
  useEffect(() => {
40
40
  isMounted.current = true;
41
- try {
42
- const playerState = TrackPlayer.getState();
43
- if (isMounted.current) {
44
- setTrack(playerState.currentTrack);
45
- setIsReady(true);
41
+ const initializeTrack = async () => {
42
+ try {
43
+ const playerState = await TrackPlayer.getState();
44
+ if (isMounted.current) {
45
+ setTrack(playerState.currentTrack);
46
+ setIsReady(true);
47
+ }
46
48
  }
47
- }
48
- catch (error) {
49
- console.error('[useOnChangeTrack] Failed to get initial state:', error);
50
- if (isMounted.current) {
51
- setTrack(null);
52
- setIsReady(true);
49
+ catch (error) {
50
+ console.error('[useOnChangeTrack] Failed to get initial state:', error);
51
+ if (isMounted.current) {
52
+ setTrack(null);
53
+ setIsReady(true);
54
+ }
53
55
  }
54
- }
56
+ };
57
+ initializeTrack();
55
58
  return () => {
56
59
  isMounted.current = false;
57
60
  };
@@ -1,5 +1,5 @@
1
1
  import { useEffect, useState } from 'react';
2
- import { TrackPlayer } from '../index';
2
+ import { callbackManager } from './callbackManager';
3
3
  /**
4
4
  * Hook to get the current playback progress
5
5
  * @returns Object with current position, total duration, and manual seek indicator
@@ -9,7 +9,7 @@ export function useOnPlaybackProgressChange() {
9
9
  const [totalDuration, setTotalDuration] = useState(0);
10
10
  const [isManuallySeeked, setIsManuallySeeked] = useState(undefined);
11
11
  useEffect(() => {
12
- TrackPlayer.onPlaybackProgressChange((newPosition, newTotalDuration, newIsManuallySeeked) => {
12
+ return callbackManager.subscribeToPlaybackProgressChange((newPosition, newTotalDuration, newIsManuallySeeked) => {
13
13
  setPosition(newPosition);
14
14
  setTotalDuration(newTotalDuration);
15
15
  setIsManuallySeeked(newIsManuallySeeked);
@@ -37,21 +37,24 @@ export function useOnPlaybackStateChange() {
37
37
  // Initialize with current state from the player
38
38
  useEffect(() => {
39
39
  isMounted.current = true;
40
- // Get initial state synchronously
41
- try {
42
- const playerState = TrackPlayer.getState();
43
- if (isMounted.current) {
44
- setState(playerState.currentState);
45
- setIsReady(true);
40
+ // Get initial state asynchronously
41
+ const initializeState = async () => {
42
+ try {
43
+ const playerState = await TrackPlayer.getState();
44
+ if (isMounted.current) {
45
+ setState(playerState.currentState);
46
+ setIsReady(true);
47
+ }
46
48
  }
47
- }
48
- catch (error) {
49
- console.error('[useOnPlaybackStateChange] Failed to get initial state:', error);
50
- if (isMounted.current) {
51
- setState('stopped');
52
- setIsReady(true);
49
+ catch (error) {
50
+ console.error('[useOnPlaybackStateChange] Failed to get initial state:', error);
51
+ if (isMounted.current) {
52
+ setState('stopped');
53
+ setIsReady(true);
54
+ }
53
55
  }
54
- }
56
+ };
57
+ initializeState();
55
58
  return () => {
56
59
  isMounted.current = false;
57
60
  };
@@ -0,0 +1,48 @@
1
+ import type { Playlist, TrackItem } from '../types/PlayerQueue';
2
+ export interface UsePlaylistResult {
3
+ /** The currently loaded playlist */
4
+ currentPlaylist: Playlist | null;
5
+ /** ID of the currently loaded playlist */
6
+ currentPlaylistId: string | null;
7
+ /** All available playlists */
8
+ allPlaylists: Playlist[];
9
+ /** All tracks from all playlists (flattened) */
10
+ allTracks: TrackItem[];
11
+ /** Whether the playlists are currently loading */
12
+ isLoading: boolean;
13
+ /** Manually refresh playlist data */
14
+ refreshPlaylists: () => void;
15
+ }
16
+ /**
17
+ * Hook to manage playlist state
18
+ *
19
+ * Provides current playlist, all playlists, and all tracks across playlists.
20
+ * Automatically refreshes when:
21
+ * - Component mounts
22
+ * - Track changes (to update currentPlaylistId)
23
+ * - Playlists are modified via PlayerQueue methods
24
+ *
25
+ * Call `refreshPlaylists()` after creating/deleting playlists to update the state.
26
+ *
27
+ * @returns Object containing playlist state and refresh function
28
+ *
29
+ * @example
30
+ * ```tsx
31
+ * function MyComponent() {
32
+ * const { currentPlaylist, allTracks, refreshPlaylists } = usePlaylist();
33
+ *
34
+ * const handleCreatePlaylist = () => {
35
+ * PlayerQueue.createPlaylist('New Playlist');
36
+ * refreshPlaylists(); // Refresh to see the new playlist
37
+ * };
38
+ *
39
+ * return (
40
+ * <View>
41
+ * <Text>{currentPlaylist?.name}</Text>
42
+ * <Text>Total tracks: {allTracks.length}</Text>
43
+ * </View>
44
+ * );
45
+ * }
46
+ * ```
47
+ */
48
+ export declare function usePlaylist(): UsePlaylistResult;
@@ -0,0 +1,136 @@
1
+ import { useEffect, useState, useRef, useCallback } from 'react';
2
+ import { PlayerQueue } from '../index';
3
+ import { callbackManager } from './callbackManager';
4
+ /**
5
+ * Hook to manage playlist state
6
+ *
7
+ * Provides current playlist, all playlists, and all tracks across playlists.
8
+ * Automatically refreshes when:
9
+ * - Component mounts
10
+ * - Track changes (to update currentPlaylistId)
11
+ * - Playlists are modified via PlayerQueue methods
12
+ *
13
+ * Call `refreshPlaylists()` after creating/deleting playlists to update the state.
14
+ *
15
+ * @returns Object containing playlist state and refresh function
16
+ *
17
+ * @example
18
+ * ```tsx
19
+ * function MyComponent() {
20
+ * const { currentPlaylist, allTracks, refreshPlaylists } = usePlaylist();
21
+ *
22
+ * const handleCreatePlaylist = () => {
23
+ * PlayerQueue.createPlaylist('New Playlist');
24
+ * refreshPlaylists(); // Refresh to see the new playlist
25
+ * };
26
+ *
27
+ * return (
28
+ * <View>
29
+ * <Text>{currentPlaylist?.name}</Text>
30
+ * <Text>Total tracks: {allTracks.length}</Text>
31
+ * </View>
32
+ * );
33
+ * }
34
+ * ```
35
+ */
36
+ export function usePlaylist() {
37
+ const [currentPlaylist, setCurrentPlaylist] = useState(null);
38
+ const [currentPlaylistId, setCurrentPlaylistId] = useState(null);
39
+ const [allPlaylists, setAllPlaylists] = useState([]);
40
+ const [allTracks, setAllTracks] = useState([]);
41
+ const [isLoading, setIsLoading] = useState(true);
42
+ const isMounted = useRef(true);
43
+ const hasSubscribed = useRef(false);
44
+ const refreshPlaylists = useCallback(() => {
45
+ if (!isMounted.current)
46
+ return;
47
+ try {
48
+ // Get current playlist ID
49
+ const playlistId = PlayerQueue.getCurrentPlaylistId();
50
+ if (!isMounted.current)
51
+ return;
52
+ setCurrentPlaylistId(playlistId);
53
+ // Get current playlist details
54
+ if (playlistId) {
55
+ const playlist = PlayerQueue.getPlaylist(playlistId);
56
+ if (isMounted.current) {
57
+ setCurrentPlaylist(playlist);
58
+ }
59
+ }
60
+ else {
61
+ if (isMounted.current) {
62
+ setCurrentPlaylist(null);
63
+ }
64
+ }
65
+ // Get all playlists
66
+ const playlists = PlayerQueue.getAllPlaylists();
67
+ if (!isMounted.current)
68
+ return;
69
+ setAllPlaylists(playlists);
70
+ // Get all tracks from all playlists (deduplicated by id)
71
+ const trackMap = new Map();
72
+ playlists.forEach((playlist) => {
73
+ playlist.tracks.forEach((track) => {
74
+ if (!trackMap.has(track.id)) {
75
+ trackMap.set(track.id, track);
76
+ }
77
+ });
78
+ });
79
+ if (isMounted.current) {
80
+ setAllTracks(Array.from(trackMap.values()));
81
+ setIsLoading(false);
82
+ }
83
+ }
84
+ catch (error) {
85
+ console.error('[usePlaylist] Error refreshing playlists:', error);
86
+ if (isMounted.current) {
87
+ setIsLoading(false);
88
+ }
89
+ }
90
+ }, []);
91
+ // Initialize and setup mounted ref
92
+ useEffect(() => {
93
+ isMounted.current = true;
94
+ // Initial load
95
+ refreshPlaylists();
96
+ return () => {
97
+ isMounted.current = false;
98
+ };
99
+ }, [refreshPlaylists]);
100
+ // Subscribe to native playlist changes (only once)
101
+ useEffect(() => {
102
+ if (hasSubscribed.current)
103
+ return;
104
+ hasSubscribed.current = true;
105
+ try {
106
+ PlayerQueue.onPlaylistsChanged(() => {
107
+ if (isMounted.current) {
108
+ refreshPlaylists();
109
+ }
110
+ });
111
+ }
112
+ catch (error) {
113
+ console.error('[usePlaylist] Error setting up playlist listener:', error);
114
+ }
115
+ }, [refreshPlaylists]);
116
+ // Also refresh when track changes (as it might indicate playlist loaded)
117
+ useEffect(() => {
118
+ const unsubscribe = callbackManager.subscribeToTrackChange(() => {
119
+ // Refresh to update currentPlaylistId when track changes
120
+ if (isMounted.current) {
121
+ refreshPlaylists();
122
+ }
123
+ });
124
+ return () => {
125
+ unsubscribe();
126
+ };
127
+ }, [refreshPlaylists]);
128
+ return {
129
+ currentPlaylist,
130
+ currentPlaylistId,
131
+ allPlaylists,
132
+ allTracks,
133
+ isLoading,
134
+ refreshPlaylists,
135
+ };
136
+ }
package/lib/index.d.ts CHANGED
@@ -2,14 +2,20 @@ import type { PlayerQueue as PlayerQueueType, TrackPlayer as TrackPlayerType } f
2
2
  import type { AndroidAutoMediaLibrary as AndroidAutoMediaLibraryType } from './specs/AndroidAutoMediaLibrary.nitro';
3
3
  import type { AudioDevices as AudioDevicesType } from './specs/AudioDevices.nitro';
4
4
  import type { AudioRoutePicker as AudioRoutePickerType } from './specs/AudioRoutePicker.nitro';
5
+ import type { DownloadManager as DownloadManagerType } from './specs/DownloadManager.nitro';
6
+ import type { Equalizer as EqualizerType } from './specs/Equalizer.nitro';
5
7
  export declare const PlayerQueue: PlayerQueueType;
6
8
  export declare const TrackPlayer: TrackPlayerType;
7
9
  export declare const AndroidAutoMediaLibrary: AndroidAutoMediaLibraryType | null;
8
10
  export declare const AudioDevices: AudioDevicesType | null;
9
11
  export declare const AudioRoutePicker: AudioRoutePickerType | null;
12
+ export declare const DownloadManager: DownloadManagerType;
13
+ export declare const Equalizer: EqualizerType;
10
14
  export * from './hooks';
11
15
  export * from './types/PlayerQueue';
12
16
  export * from './types/AndroidAutoMediaLibrary';
17
+ export * from './types/DownloadTypes';
18
+ export * from './types/EqualizerTypes';
13
19
  export type { TAudioDevice } from './specs/AudioDevices.nitro';
14
20
  export type { RepeatMode } from './specs/TrackPlayer.nitro';
15
21
  export { AndroidAutoMediaLibraryHelper } from './utils/androidAutoMediaLibrary';
package/lib/index.js CHANGED
@@ -15,10 +15,16 @@ export const AudioDevices = Platform.OS === 'android'
15
15
  export const AudioRoutePicker = Platform.OS === 'ios'
16
16
  ? NitroModules.createHybridObject('AudioRoutePicker')
17
17
  : null;
18
+ // Download Manager
19
+ export const DownloadManager = NitroModules.createHybridObject('DownloadManager');
20
+ // Equalizer
21
+ export const Equalizer = NitroModules.createHybridObject('Equalizer');
18
22
  // Export hooks
19
23
  export * from './hooks';
20
24
  // Export types
21
25
  export * from './types/PlayerQueue';
22
26
  export * from './types/AndroidAutoMediaLibrary';
27
+ export * from './types/DownloadTypes';
28
+ export * from './types/EqualizerTypes';
23
29
  // Export utilities
24
30
  export { AndroidAutoMediaLibraryHelper } from './utils/androidAutoMediaLibrary';