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.
Files changed (191) hide show
  1. package/NitroPlayer.podspec +31 -0
  2. package/README.md +610 -0
  3. package/android/CMakeLists.txt +29 -0
  4. package/android/build.gradle +147 -0
  5. package/android/fix-prefab.gradle +51 -0
  6. package/android/gradle.properties +5 -0
  7. package/android/src/main/AndroidManifest.xml +2 -0
  8. package/android/src/main/cpp/cpp-adapter.cpp +7 -0
  9. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrary.kt +29 -0
  10. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAudioDevices.kt +116 -0
  11. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridPlayerQueue.kt +167 -0
  12. package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridTrackPlayer.kt +93 -0
  13. package/android/src/main/java/com/margelo/nitro/nitroplayer/NitroPlayerPackage.kt +21 -0
  14. package/android/src/main/java/com/margelo/nitro/nitroplayer/connection/AndroidAutoConnectionDetector.kt +171 -0
  15. package/android/src/main/java/com/margelo/nitro/nitroplayer/core/TrackPlayerCore.kt +639 -0
  16. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaBrowserService.kt +352 -0
  17. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibrary.kt +58 -0
  18. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibraryManager.kt +77 -0
  19. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibraryParser.kt +73 -0
  20. package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaSessionManager.kt +506 -0
  21. package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/Playlist.kt +21 -0
  22. package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/PlaylistManager.kt +454 -0
  23. package/android/src/main/java/com/margelo/nitro/nitroplayer/queue/Queue.kt +94 -0
  24. package/android/src/main/java/com/margelo/nitro/nitroplayer/queue/QueueManager.kt +143 -0
  25. package/ios/HybridAudioRoutePicker.swift +53 -0
  26. package/ios/HybridTrackPlayer.swift +100 -0
  27. package/ios/core/TrackPlayerCore.swift +1040 -0
  28. package/ios/media/MediaSessionManager.swift +230 -0
  29. package/ios/playlist/PlaylistManager.swift +446 -0
  30. package/ios/playlist/PlaylistModel.swift +49 -0
  31. package/ios/queue/HybridPlayerQueue.swift +95 -0
  32. package/ios/queue/Queue.swift +126 -0
  33. package/ios/queue/QueueManager.swift +157 -0
  34. package/lib/hooks/index.d.ts +6 -0
  35. package/lib/hooks/index.js +6 -0
  36. package/lib/hooks/useAndroidAutoConnection.d.ts +13 -0
  37. package/lib/hooks/useAndroidAutoConnection.js +26 -0
  38. package/lib/hooks/useAudioDevices.d.ts +26 -0
  39. package/lib/hooks/useAudioDevices.js +55 -0
  40. package/lib/hooks/useOnChangeTrack.d.ts +9 -0
  41. package/lib/hooks/useOnChangeTrack.js +17 -0
  42. package/lib/hooks/useOnPlaybackProgressChange.d.ts +9 -0
  43. package/lib/hooks/useOnPlaybackProgressChange.js +19 -0
  44. package/lib/hooks/useOnPlaybackStateChange.d.ts +9 -0
  45. package/lib/hooks/useOnPlaybackStateChange.js +17 -0
  46. package/lib/hooks/useOnSeek.d.ts +8 -0
  47. package/lib/hooks/useOnSeek.js +17 -0
  48. package/lib/index.d.ts +14 -0
  49. package/lib/index.js +24 -0
  50. package/lib/specs/AndroidAutoMediaLibrary.nitro.d.ts +21 -0
  51. package/lib/specs/AndroidAutoMediaLibrary.nitro.js +1 -0
  52. package/lib/specs/AudioDevices.nitro.d.ts +24 -0
  53. package/lib/specs/AudioDevices.nitro.js +1 -0
  54. package/lib/specs/AudioRoutePicker.nitro.d.ts +10 -0
  55. package/lib/specs/AudioRoutePicker.nitro.js +1 -0
  56. package/lib/specs/TrackPlayer.nitro.d.ts +39 -0
  57. package/lib/specs/TrackPlayer.nitro.js +1 -0
  58. package/lib/types/AndroidAutoMediaLibrary.d.ts +44 -0
  59. package/lib/types/AndroidAutoMediaLibrary.js +1 -0
  60. package/lib/types/PlayerQueue.d.ts +32 -0
  61. package/lib/types/PlayerQueue.js +1 -0
  62. package/lib/utils/androidAutoMediaLibrary.d.ts +47 -0
  63. package/lib/utils/androidAutoMediaLibrary.js +62 -0
  64. package/nitro.json +31 -0
  65. package/nitrogen/generated/.gitattributes +1 -0
  66. package/nitrogen/generated/android/NitroPlayer+autolinking.cmake +91 -0
  67. package/nitrogen/generated/android/NitroPlayer+autolinking.gradle +27 -0
  68. package/nitrogen/generated/android/NitroPlayerOnLoad.cpp +88 -0
  69. package/nitrogen/generated/android/NitroPlayerOnLoad.hpp +25 -0
  70. package/nitrogen/generated/android/c++/JFunc_void_TrackItem_std__optional_Reason_.hpp +85 -0
  71. package/nitrogen/generated/android/c++/JFunc_void_TrackPlayerState_std__optional_Reason_.hpp +80 -0
  72. package/nitrogen/generated/android/c++/JFunc_void_bool.hpp +75 -0
  73. package/nitrogen/generated/android/c++/JFunc_void_double_double.hpp +75 -0
  74. package/nitrogen/generated/android/c++/JFunc_void_double_double_std__optional_bool_.hpp +76 -0
  75. package/nitrogen/generated/android/c++/JFunc_void_std__string_Playlist_std__optional_QueueOperation_.hpp +88 -0
  76. package/nitrogen/generated/android/c++/JFunc_void_std__vector_Playlist__std__optional_QueueOperation_.hpp +106 -0
  77. package/nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.cpp +55 -0
  78. package/nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.hpp +66 -0
  79. package/nitrogen/generated/android/c++/JHybridAudioDevicesSpec.cpp +70 -0
  80. package/nitrogen/generated/android/c++/JHybridAudioDevicesSpec.hpp +66 -0
  81. package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.cpp +143 -0
  82. package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.hpp +77 -0
  83. package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp +137 -0
  84. package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.hpp +78 -0
  85. package/nitrogen/generated/android/c++/JPlayerConfig.hpp +65 -0
  86. package/nitrogen/generated/android/c++/JPlayerState.hpp +87 -0
  87. package/nitrogen/generated/android/c++/JPlaylist.hpp +99 -0
  88. package/nitrogen/generated/android/c++/JQueueOperation.hpp +65 -0
  89. package/nitrogen/generated/android/c++/JReason.hpp +65 -0
  90. package/nitrogen/generated/android/c++/JTAudioDevice.hpp +69 -0
  91. package/nitrogen/generated/android/c++/JTrackItem.hpp +86 -0
  92. package/nitrogen/generated/android/c++/JTrackPlayerState.hpp +62 -0
  93. package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.cpp +26 -0
  94. package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.hpp +77 -0
  95. package/nitrogen/generated/android/c++/JVariant_NullType_String.cpp +26 -0
  96. package/nitrogen/generated/android/c++/JVariant_NullType_String.hpp +70 -0
  97. package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.cpp +26 -0
  98. package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.hpp +74 -0
  99. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_TrackItem_std__optional_Reason_.kt +80 -0
  100. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_TrackPlayerState_std__optional_Reason_.kt +80 -0
  101. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_bool.kt +80 -0
  102. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_double_double.kt +80 -0
  103. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_double_double_std__optional_bool_.kt +80 -0
  104. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__string_Playlist_std__optional_QueueOperation_.kt +80 -0
  105. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__vector_Playlist__std__optional_QueueOperation_.kt +80 -0
  106. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrarySpec.kt +61 -0
  107. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridAudioDevicesSpec.kt +61 -0
  108. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridPlayerQueueSpec.kt +116 -0
  109. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt +134 -0
  110. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/NitroPlayerOnLoad.kt +35 -0
  111. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerConfig.kt +44 -0
  112. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerState.kt +53 -0
  113. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Playlist.kt +50 -0
  114. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/QueueOperation.kt +23 -0
  115. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Reason.kt +23 -0
  116. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TAudioDevice.kt +47 -0
  117. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackItem.kt +56 -0
  118. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackPlayerState.kt +22 -0
  119. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_Playlist.kt +59 -0
  120. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_String.kt +59 -0
  121. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_TrackItem.kt +59 -0
  122. package/nitrogen/generated/ios/NitroPlayer+autolinking.rb +60 -0
  123. package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.cpp +123 -0
  124. package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.hpp +531 -0
  125. package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Umbrella.hpp +80 -0
  126. package/nitrogen/generated/ios/NitroPlayerAutolinking.mm +49 -0
  127. package/nitrogen/generated/ios/NitroPlayerAutolinking.swift +55 -0
  128. package/nitrogen/generated/ios/c++/HybridAudioRoutePickerSpecSwift.cpp +11 -0
  129. package/nitrogen/generated/ios/c++/HybridAudioRoutePickerSpecSwift.hpp +74 -0
  130. package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.cpp +11 -0
  131. package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.hpp +167 -0
  132. package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.cpp +11 -0
  133. package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.hpp +174 -0
  134. package/nitrogen/generated/ios/swift/Func_void_TrackItem_std__optional_Reason_.swift +47 -0
  135. package/nitrogen/generated/ios/swift/Func_void_TrackPlayerState_std__optional_Reason_.swift +47 -0
  136. package/nitrogen/generated/ios/swift/Func_void_bool.swift +47 -0
  137. package/nitrogen/generated/ios/swift/Func_void_double_double.swift +47 -0
  138. package/nitrogen/generated/ios/swift/Func_void_double_double_std__optional_bool_.swift +54 -0
  139. package/nitrogen/generated/ios/swift/Func_void_std__string_Playlist_std__optional_QueueOperation_.swift +47 -0
  140. package/nitrogen/generated/ios/swift/Func_void_std__vector_Playlist__std__optional_QueueOperation_.swift +47 -0
  141. package/nitrogen/generated/ios/swift/HybridAudioRoutePickerSpec.swift +56 -0
  142. package/nitrogen/generated/ios/swift/HybridAudioRoutePickerSpec_cxx.swift +130 -0
  143. package/nitrogen/generated/ios/swift/HybridPlayerQueueSpec.swift +68 -0
  144. package/nitrogen/generated/ios/swift/HybridPlayerQueueSpec_cxx.swift +349 -0
  145. package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec.swift +69 -0
  146. package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec_cxx.swift +325 -0
  147. package/nitrogen/generated/ios/swift/PlayerConfig.swift +115 -0
  148. package/nitrogen/generated/ios/swift/PlayerState.swift +181 -0
  149. package/nitrogen/generated/ios/swift/Playlist.swift +182 -0
  150. package/nitrogen/generated/ios/swift/QueueOperation.swift +48 -0
  151. package/nitrogen/generated/ios/swift/Reason.swift +48 -0
  152. package/nitrogen/generated/ios/swift/TrackItem.swift +147 -0
  153. package/nitrogen/generated/ios/swift/TrackPlayerState.swift +44 -0
  154. package/nitrogen/generated/ios/swift/Variant_NullType_Playlist.swift +18 -0
  155. package/nitrogen/generated/ios/swift/Variant_NullType_String.swift +18 -0
  156. package/nitrogen/generated/ios/swift/Variant_NullType_TrackItem.swift +18 -0
  157. package/nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.cpp +22 -0
  158. package/nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.hpp +63 -0
  159. package/nitrogen/generated/shared/c++/HybridAudioDevicesSpec.cpp +22 -0
  160. package/nitrogen/generated/shared/c++/HybridAudioDevicesSpec.hpp +65 -0
  161. package/nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.cpp +21 -0
  162. package/nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.hpp +62 -0
  163. package/nitrogen/generated/shared/c++/HybridPlayerQueueSpec.cpp +33 -0
  164. package/nitrogen/generated/shared/c++/HybridPlayerQueueSpec.hpp +87 -0
  165. package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp +34 -0
  166. package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.hpp +91 -0
  167. package/nitrogen/generated/shared/c++/PlayerConfig.hpp +83 -0
  168. package/nitrogen/generated/shared/c++/PlayerState.hpp +103 -0
  169. package/nitrogen/generated/shared/c++/Playlist.hpp +97 -0
  170. package/nitrogen/generated/shared/c++/QueueOperation.hpp +84 -0
  171. package/nitrogen/generated/shared/c++/Reason.hpp +84 -0
  172. package/nitrogen/generated/shared/c++/TAudioDevice.hpp +87 -0
  173. package/nitrogen/generated/shared/c++/TrackItem.hpp +102 -0
  174. package/nitrogen/generated/shared/c++/TrackPlayerState.hpp +80 -0
  175. package/package.json +172 -0
  176. package/react-native.config.js +16 -0
  177. package/src/hooks/index.ts +6 -0
  178. package/src/hooks/useAndroidAutoConnection.ts +30 -0
  179. package/src/hooks/useAudioDevices.ts +64 -0
  180. package/src/hooks/useOnChangeTrack.ts +24 -0
  181. package/src/hooks/useOnPlaybackProgressChange.ts +30 -0
  182. package/src/hooks/useOnPlaybackStateChange.ts +24 -0
  183. package/src/hooks/useOnSeek.ts +25 -0
  184. package/src/index.ts +47 -0
  185. package/src/specs/AndroidAutoMediaLibrary.nitro.ts +22 -0
  186. package/src/specs/AudioDevices.nitro.ts +25 -0
  187. package/src/specs/AudioRoutePicker.nitro.ts +9 -0
  188. package/src/specs/TrackPlayer.nitro.ts +81 -0
  189. package/src/types/AndroidAutoMediaLibrary.ts +58 -0
  190. package/src/types/PlayerQueue.ts +38 -0
  191. package/src/utils/androidAutoMediaLibrary.ts +66 -0
package/package.json ADDED
@@ -0,0 +1,172 @@
1
+ {
2
+ "name": "react-native-nitro-player",
3
+ "version": "0.0.1",
4
+ "description": "react-native-nitro-player",
5
+ "main": "lib/index",
6
+ "module": "lib/index",
7
+ "types": "lib/index.d.ts",
8
+ "react-native": "src/index",
9
+ "source": "src/index",
10
+ "files": [
11
+ "src",
12
+ "react-native.config.js",
13
+ "lib",
14
+ "nitrogen",
15
+ "android/build.gradle",
16
+ "android/gradle.properties",
17
+ "android/fix-prefab.gradle",
18
+ "android/CMakeLists.txt",
19
+ "android/src",
20
+ "ios/**/*.h",
21
+ "ios/**/*.m",
22
+ "ios/**/*.mm",
23
+ "ios/**/*.cpp",
24
+ "ios/**/*.swift",
25
+ "app.plugin.js",
26
+ "nitro.json",
27
+ "*.podspec",
28
+ "README.md"
29
+ ],
30
+ "scripts": {
31
+ "postinstall": "tsc || exit 0;",
32
+ "typecheck": "tsc --noEmit",
33
+ "clean": "rm -rf android/build node_modules/**/android/build lib",
34
+ "lint": "eslint \"**/*.{js,ts,tsx}\" --fix",
35
+ "lint-ci": "eslint \"**/*.{js,ts,tsx}\" -f @jamesacarr/github-actions",
36
+ "typescript": "tsc",
37
+ "specs": "tsc --noEmit false && nitrogen --logLevel=\"debug\"",
38
+ "release": "release-it"
39
+ },
40
+ "keywords": [
41
+ "react-native",
42
+ "nitro"
43
+ ],
44
+ "repository": {
45
+ "type": "git",
46
+ "url": "git+https://github.com/mrousavy/nitro.git"
47
+ },
48
+ "author": "Marc Rousavy <me@mrousavy.com> (https://github.com/mrousavy)",
49
+ "license": "MIT",
50
+ "bugs": {
51
+ "url": "https://github.com/mrousavy/nitro/issues"
52
+ },
53
+ "homepage": "https://github.com/mrousavy/nitro#readme",
54
+ "publishConfig": {
55
+ "registry": "https://registry.npmjs.org/"
56
+ },
57
+ "devDependencies": {
58
+ "@react-native/eslint-config": "0.82.0",
59
+ "@release-it-plugins/workspaces": "^5.0.3",
60
+ "@release-it/bumper": "^7.0.5",
61
+ "@release-it/conventional-changelog": "^10.0.1",
62
+ "@types/react": "^19.1.03",
63
+ "eslint": "^8.57.0",
64
+ "eslint-config-prettier": "^9.1.0",
65
+ "eslint-plugin-prettier": "^5.2.1",
66
+ "nitrogen": "*",
67
+ "prettier": "^3.3.3",
68
+ "react": "19.1.1",
69
+ "react-native": "0.82.0",
70
+ "react-native-nitro-modules": "*",
71
+ "release-it": "^19.0.4",
72
+ "typescript": "^5.8.3"
73
+ },
74
+ "peerDependencies": {
75
+ "react": "*",
76
+ "react-native": "*",
77
+ "react-native-nitro-modules": "*"
78
+ },
79
+ "eslintConfig": {
80
+ "root": true,
81
+ "extends": [
82
+ "@react-native",
83
+ "prettier"
84
+ ],
85
+ "plugins": [
86
+ "prettier"
87
+ ],
88
+ "rules": {
89
+ "prettier/prettier": [
90
+ "warn",
91
+ {
92
+ "quoteProps": "consistent",
93
+ "singleQuote": true,
94
+ "tabWidth": 2,
95
+ "trailingComma": "es5",
96
+ "useTabs": false
97
+ }
98
+ ]
99
+ }
100
+ },
101
+ "eslintIgnore": [
102
+ "node_modules/",
103
+ "lib/"
104
+ ],
105
+ "prettier": {
106
+ "quoteProps": "consistent",
107
+ "singleQuote": true,
108
+ "tabWidth": 2,
109
+ "trailingComma": "es5",
110
+ "useTabs": false,
111
+ "semi": false
112
+ },
113
+ "release-it": {
114
+ "npm": {
115
+ "publish": true
116
+ },
117
+ "git": {
118
+ "commitMessage": "chore: release ${version}",
119
+ "tagName": "v${version}",
120
+ "requireCleanWorkingDir": false
121
+ },
122
+ "github": {
123
+ "release": true
124
+ },
125
+ "plugins": {
126
+ "@release-it/bumper": {
127
+ "in": "package.json",
128
+ "out": [
129
+ {
130
+ "file": "package.json",
131
+ "path": "version"
132
+ },
133
+ {
134
+ "file": "../package.json",
135
+ "path": "version"
136
+ },
137
+ {
138
+ "file": "../example/package.json",
139
+ "path": "version"
140
+ }
141
+ ]
142
+ },
143
+ "@release-it/conventional-changelog": {
144
+ "preset": {
145
+ "name": "conventionalcommits",
146
+ "types": [
147
+ {
148
+ "type": "feat",
149
+ "section": "✨ Features"
150
+ },
151
+ {
152
+ "type": "perf",
153
+ "section": "💨 Performance Improvements"
154
+ },
155
+ {
156
+ "type": "fix",
157
+ "section": "🐛 Bug Fixes"
158
+ },
159
+ {
160
+ "type": "chore(deps)",
161
+ "section": "🛠️ Dependency Upgrades"
162
+ },
163
+ {
164
+ "type": "docs",
165
+ "section": "📚 Documentation"
166
+ }
167
+ ]
168
+ }
169
+ }
170
+ }
171
+ }
172
+ }
@@ -0,0 +1,16 @@
1
+ // https://github.com/react-native-community/cli/blob/main/docs/dependencies.md
2
+
3
+ module.exports = {
4
+ dependency: {
5
+ platforms: {
6
+ /**
7
+ * @type {import('@react-native-community/cli-types').IOSDependencyParams}
8
+ */
9
+ ios: {},
10
+ /**
11
+ * @type {import('@react-native-community/cli-types').AndroidDependencyParams}
12
+ */
13
+ android: {},
14
+ },
15
+ },
16
+ }
@@ -0,0 +1,6 @@
1
+ export { useOnChangeTrack } from './useOnChangeTrack'
2
+ export { useOnPlaybackStateChange } from './useOnPlaybackStateChange'
3
+ export { useOnSeek } from './useOnSeek'
4
+ export { useOnPlaybackProgressChange } from './useOnPlaybackProgressChange'
5
+ export { useAndroidAutoConnection } from './useAndroidAutoConnection'
6
+ export { useAudioDevices } from './useAudioDevices'
@@ -0,0 +1,30 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { TrackPlayer } from '../index'
3
+
4
+ /**
5
+ * Hook to detect Android Auto connection status using the official Android for Cars API
6
+ * Based on: https://developer.android.com/training/cars/apps#car-connection
7
+ *
8
+ * @returns Object with isConnected boolean
9
+ *
10
+ * @example
11
+ * const { isConnected } = useAndroidAutoConnection();
12
+ * console.log('Android Auto connected:', isConnected);
13
+ */
14
+ export function useAndroidAutoConnection() {
15
+ const [isConnected, setIsConnected] = useState<boolean>(false)
16
+
17
+ useEffect(() => {
18
+ // Set initial state
19
+ const initialState = TrackPlayer.isAndroidAutoConnected()
20
+ setIsConnected(initialState)
21
+
22
+ // Listen for connection changes
23
+ TrackPlayer.onAndroidAutoConnectionChange((connected: boolean) => {
24
+ setIsConnected(connected)
25
+ console.log('🚗 Android Auto connection changed:', connected)
26
+ })
27
+ }, [])
28
+
29
+ return { isConnected }
30
+ }
@@ -0,0 +1,64 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { Platform } from 'react-native'
3
+ import { NitroModules } from 'react-native-nitro-modules'
4
+ import type { AudioDevices as AudioDevicesType } from '../specs/AudioDevices.nitro'
5
+ import type { TAudioDevice } from '../specs/AudioDevices.nitro'
6
+
7
+ /**
8
+ * Hook to get audio devices (Android only)
9
+ *
10
+ * Polls for device changes every 2 seconds
11
+ *
12
+ * @returns Object containing the current list of audio devices
13
+ *
14
+ * @example
15
+ * ```tsx
16
+ * function MyComponent() {
17
+ * const { devices } = useAudioDevices()
18
+ *
19
+ * return (
20
+ * <View>
21
+ * {devices.map(device => (
22
+ * <Text key={device.id}>{device.name}</Text>
23
+ * ))}
24
+ * </View>
25
+ * )
26
+ * }
27
+ * ```
28
+ */
29
+ export function useAudioDevices() {
30
+ const [devices, setDevices] = useState<TAudioDevice[]>([])
31
+
32
+ useEffect(() => {
33
+ if (Platform.OS !== 'android') {
34
+ return undefined
35
+ }
36
+
37
+ try {
38
+ const AudioDevices =
39
+ NitroModules.createHybridObject<AudioDevicesType>('AudioDevices')
40
+
41
+ // Get initial devices
42
+ const updateDevices = () => {
43
+ try {
44
+ const currentDevices = AudioDevices.getAudioDevices()
45
+ setDevices(currentDevices)
46
+ } catch (error) {
47
+ console.error('Error getting audio devices:', error)
48
+ }
49
+ }
50
+
51
+ updateDevices()
52
+
53
+ // Poll for changes every 2 seconds
54
+ const interval = setInterval(updateDevices, 2000)
55
+
56
+ return () => clearInterval(interval)
57
+ } catch (error) {
58
+ console.error('Error setting up audio devices polling:', error)
59
+ return undefined
60
+ }
61
+ }, [])
62
+
63
+ return { devices }
64
+ }
@@ -0,0 +1,24 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { TrackPlayer } from '../index'
3
+ import type { TrackItem, Reason } from '../types/PlayerQueue'
4
+
5
+ /**
6
+ * Hook to get the current track and track change reason
7
+ * @returns Object with current track and reason, or undefined if no track is playing
8
+ */
9
+ export function useOnChangeTrack(): {
10
+ track: TrackItem | undefined
11
+ reason: Reason | undefined
12
+ } {
13
+ const [track, setTrack] = useState<TrackItem | undefined>(undefined)
14
+ const [reason, setReason] = useState<Reason | undefined>(undefined)
15
+
16
+ useEffect(() => {
17
+ TrackPlayer.onChangeTrack((newTrack, newReason) => {
18
+ setTrack(newTrack)
19
+ setReason(newReason)
20
+ })
21
+ }, [])
22
+
23
+ return { track, reason }
24
+ }
@@ -0,0 +1,30 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { TrackPlayer } from '../index'
3
+
4
+ /**
5
+ * Hook to get the current playback progress
6
+ * @returns Object with current position, total duration, and manual seek indicator
7
+ */
8
+ export function useOnPlaybackProgressChange(): {
9
+ position: number
10
+ totalDuration: number
11
+ isManuallySeeked: boolean | undefined
12
+ } {
13
+ const [position, setPosition] = useState<number>(0)
14
+ const [totalDuration, setTotalDuration] = useState<number>(0)
15
+ const [isManuallySeeked, setIsManuallySeeked] = useState<boolean | undefined>(
16
+ undefined
17
+ )
18
+
19
+ useEffect(() => {
20
+ TrackPlayer.onPlaybackProgressChange(
21
+ (newPosition, newTotalDuration, newIsManuallySeeked) => {
22
+ setPosition(newPosition)
23
+ setTotalDuration(newTotalDuration)
24
+ setIsManuallySeeked(newIsManuallySeeked)
25
+ }
26
+ )
27
+ }, [])
28
+
29
+ return { position, totalDuration, isManuallySeeked }
30
+ }
@@ -0,0 +1,24 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { TrackPlayer } from '../index'
3
+ import type { TrackPlayerState, Reason } from '../types/PlayerQueue'
4
+
5
+ /**
6
+ * Hook to get the current playback state and reason
7
+ * @returns Object with current playback state and reason
8
+ */
9
+ export function useOnPlaybackStateChange(): {
10
+ state: TrackPlayerState | undefined
11
+ reason: Reason | undefined
12
+ } {
13
+ const [state, setState] = useState<TrackPlayerState | undefined>(undefined)
14
+ const [reason, setReason] = useState<Reason | undefined>(undefined)
15
+
16
+ useEffect(() => {
17
+ TrackPlayer.onPlaybackStateChange((newState, newReason) => {
18
+ setState(newState)
19
+ setReason(newReason)
20
+ })
21
+ }, [])
22
+
23
+ return { state, reason }
24
+ }
@@ -0,0 +1,25 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { TrackPlayer } from '../index'
3
+
4
+ /**
5
+ * Hook to get the last seek event information
6
+ * @returns Object with last seek position and total duration, or undefined if no seek has occurred
7
+ */
8
+ export function useOnSeek(): {
9
+ position: number | undefined
10
+ totalDuration: number | undefined
11
+ } {
12
+ const [position, setPosition] = useState<number | undefined>(undefined)
13
+ const [totalDuration, setTotalDuration] = useState<number | undefined>(
14
+ undefined
15
+ )
16
+
17
+ useEffect(() => {
18
+ TrackPlayer.onSeek((newPosition, newTotalDuration) => {
19
+ setPosition(newPosition)
20
+ setTotalDuration(newTotalDuration)
21
+ })
22
+ }, [])
23
+
24
+ return { position, totalDuration }
25
+ }
package/src/index.ts ADDED
@@ -0,0 +1,47 @@
1
+ // TODO: Export all HybridObjects here for the user
2
+
3
+ import { NitroModules } from 'react-native-nitro-modules'
4
+ import { Platform } from 'react-native'
5
+ import type {
6
+ PlayerQueue as PlayerQueueType,
7
+ TrackPlayer as TrackPlayerType,
8
+ } from './specs/TrackPlayer.nitro'
9
+ import type { AndroidAutoMediaLibrary as AndroidAutoMediaLibraryType } from './specs/AndroidAutoMediaLibrary.nitro'
10
+ import type { AudioDevices as AudioDevicesType } from './specs/AudioDevices.nitro'
11
+ import type { AudioRoutePicker as AudioRoutePickerType } from './specs/AudioRoutePicker.nitro'
12
+
13
+ export const PlayerQueue =
14
+ NitroModules.createHybridObject<PlayerQueueType>('PlayerQueue')
15
+ export const TrackPlayer =
16
+ NitroModules.createHybridObject<TrackPlayerType>('TrackPlayer')
17
+
18
+ // Android-only: Android Auto Media Library
19
+ export const AndroidAutoMediaLibrary =
20
+ Platform.OS === 'android'
21
+ ? NitroModules.createHybridObject<AndroidAutoMediaLibraryType>(
22
+ 'AndroidAutoMediaLibrary'
23
+ )
24
+ : null
25
+
26
+ // Android-only: Audio Devices
27
+ export const AudioDevices =
28
+ Platform.OS === 'android'
29
+ ? NitroModules.createHybridObject<AudioDevicesType>('AudioDevices')
30
+ : null
31
+
32
+ // iOS-only: Audio Route Picker
33
+ export const AudioRoutePicker =
34
+ Platform.OS === 'ios'
35
+ ? NitroModules.createHybridObject<AudioRoutePickerType>('AudioRoutePicker')
36
+ : null
37
+
38
+ // Export hooks
39
+ export * from './hooks'
40
+
41
+ // Export types
42
+ export * from './types/PlayerQueue'
43
+ export * from './types/AndroidAutoMediaLibrary'
44
+ export type { TAudioDevice } from './specs/AudioDevices.nitro'
45
+
46
+ // Export utilities
47
+ export { AndroidAutoMediaLibraryHelper } from './utils/androidAutoMediaLibrary'
@@ -0,0 +1,22 @@
1
+ import type { HybridObject } from 'react-native-nitro-modules'
2
+
3
+ /**
4
+ * Android Auto Media Library Manager
5
+ * Android-only HybridObject for managing Android Auto media browser structure
6
+ */
7
+ export interface AndroidAutoMediaLibrary
8
+ extends HybridObject<{ android: 'kotlin' }> {
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
+ /**
18
+ * Clear the Android Auto media library
19
+ * Falls back to showing all playlists
20
+ */
21
+ clearMediaLibrary(): void
22
+ }
@@ -0,0 +1,25 @@
1
+ import type { HybridObject } from 'react-native-nitro-modules'
2
+
3
+ export type TAudioDevice = {
4
+ id: number
5
+ name: string
6
+ type: number
7
+ isActive: boolean
8
+ }
9
+
10
+ export interface AudioDevices extends HybridObject<{ android: 'kotlin' }> {
11
+ /**
12
+ * Get the list of audio devices
13
+ *
14
+ * @returns The list of audio devices
15
+ */
16
+ getAudioDevices(): TAudioDevice[]
17
+
18
+ /**
19
+ * Set the audio device
20
+ *
21
+ * @param deviceId - The ID of the audio device
22
+ * @returns True if the audio device was set successfully, false otherwise
23
+ */
24
+ setAudioDevice(deviceId: number): boolean
25
+ }
@@ -0,0 +1,9 @@
1
+ import type { HybridObject } from 'react-native-nitro-modules'
2
+
3
+ export interface AudioRoutePicker extends HybridObject<{ ios: 'swift' }> {
4
+ /**
5
+ * Show the audio route picker view (iOS only)
6
+ * This presents a native AVRoutePickerView for selecting audio output devices like AirPlay
7
+ */
8
+ showRoutePicker(): void
9
+ }
@@ -0,0 +1,81 @@
1
+ import type { HybridObject } from 'react-native-nitro-modules'
2
+ import type {
3
+ QueueOperation,
4
+ Reason,
5
+ TrackItem,
6
+ TrackPlayerState,
7
+ PlayerState,
8
+ PlayerConfig,
9
+ Playlist,
10
+ } from '../types/PlayerQueue'
11
+
12
+ export interface PlayerQueue
13
+ extends HybridObject<{ android: 'kotlin'; ios: 'swift' }> {
14
+ // Playlist management
15
+ createPlaylist(name: string, description?: string, artwork?: string): string
16
+ deletePlaylist(playlistId: string): void
17
+ updatePlaylist(
18
+ playlistId: string,
19
+ name?: string,
20
+ description?: string,
21
+ artwork?: string
22
+ ): void
23
+ getPlaylist(playlistId: string): Playlist | null
24
+ getAllPlaylists(): Playlist[]
25
+
26
+ // Track management within playlists
27
+ addTrackToPlaylist(playlistId: string, track: TrackItem, index?: number): void
28
+ addTracksToPlaylist(
29
+ playlistId: string,
30
+ tracks: TrackItem[],
31
+ index?: number
32
+ ): void
33
+ removeTrackFromPlaylist(playlistId: string, trackId: string): void
34
+ reorderTrackInPlaylist(
35
+ playlistId: string,
36
+ trackId: string,
37
+ newIndex: number
38
+ ): void
39
+
40
+ // Playback control
41
+ loadPlaylist(playlistId: string): void
42
+ getCurrentPlaylistId(): string | null
43
+
44
+ // Events
45
+ onPlaylistsChanged(
46
+ callback: (playlists: Playlist[], operation?: QueueOperation) => void
47
+ ): void
48
+ onPlaylistChanged(
49
+ callback: (
50
+ playlistId: string,
51
+ playlist: Playlist,
52
+ operation?: QueueOperation
53
+ ) => void
54
+ ): void
55
+ }
56
+
57
+ export interface TrackPlayer
58
+ extends HybridObject<{ android: 'kotlin'; ios: 'swift' }> {
59
+ play(): void
60
+ pause(): void
61
+ playSong(songId: string, fromPlaylist?: string): void
62
+ skipToNext(): void
63
+ skipToPrevious(): void
64
+ seek(position: number): void
65
+ getState(): PlayerState
66
+ configure(config: PlayerConfig): void
67
+ onChangeTrack(callback: (track: TrackItem, reason?: Reason) => void): void
68
+ onPlaybackStateChange(
69
+ callback: (state: TrackPlayerState, reason?: Reason) => void
70
+ ): void
71
+ onSeek(callback: (position: number, totalDuration: number) => void): void
72
+ onPlaybackProgressChange(
73
+ callback: (
74
+ position: number,
75
+ totalDuration: number,
76
+ isManuallySeeked?: boolean
77
+ ) => void
78
+ ): void
79
+ onAndroidAutoConnectionChange(callback: (connected: boolean) => void): void
80
+ isAndroidAutoConnected(): boolean
81
+ }
@@ -0,0 +1,58 @@
1
+ /**
2
+ * Layout type for the Android Auto media browser
3
+ */
4
+ export type LayoutType = 'grid' | 'list'
5
+
6
+ /**
7
+ * Media type for different kinds of content
8
+ */
9
+ export type MediaType = 'folder' | 'audio' | 'playlist'
10
+
11
+ /**
12
+ * Media item that can be displayed in Android Auto
13
+ */
14
+ export interface MediaItem {
15
+ /** Unique identifier for the media item */
16
+ id: string
17
+
18
+ /** Display title */
19
+ title: string
20
+
21
+ /** Optional subtitle/description */
22
+ subtitle?: string
23
+
24
+ /** Optional icon/artwork URL */
25
+ iconUrl?: string
26
+
27
+ /** Whether this item can be played directly */
28
+ isPlayable: boolean
29
+
30
+ /** Media type */
31
+ mediaType: MediaType
32
+
33
+ /** Reference to playlist ID (for playlist items) - will load tracks from this playlist */
34
+ playlistId?: string
35
+
36
+ /** Child items for browsable folders */
37
+ children?: MediaItem[]
38
+
39
+ /** Layout type for folder items (overrides library default) */
40
+ layoutType?: LayoutType
41
+ }
42
+
43
+ /**
44
+ * Media library structure for Android Auto
45
+ */
46
+ export interface MediaLibrary {
47
+ /** Layout type for the media browser (applies to all folders by default) */
48
+ layoutType: LayoutType
49
+
50
+ /** Root level media items */
51
+ rootItems: MediaItem[]
52
+
53
+ /** Optional app name to display */
54
+ appName?: string
55
+
56
+ /** Optional app icon URL */
57
+ appIconUrl?: string
58
+ }
@@ -0,0 +1,38 @@
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
+
11
+ export interface Playlist {
12
+ id: string
13
+ name: string
14
+ description?: string | null
15
+ artwork?: string | null
16
+ tracks: TrackItem[]
17
+ }
18
+
19
+ export type QueueOperation = 'add' | 'remove' | 'clear' | 'update'
20
+
21
+ export type TrackPlayerState = 'playing' | 'paused' | 'stopped'
22
+
23
+ export type Reason = 'user_action' | 'skip' | 'end' | 'error'
24
+
25
+ export interface PlayerState {
26
+ currentTrack: TrackItem | null
27
+ currentPosition: number
28
+ totalDuration: number
29
+ currentState: TrackPlayerState
30
+ currentPlaylistId: string | null
31
+ currentIndex: number
32
+ }
33
+
34
+ export interface PlayerConfig {
35
+ androidAutoEnabled?: boolean
36
+ carPlayEnabled?: boolean
37
+ showInNotification?: boolean
38
+ }