react-native-nitro-player 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/NitroPlayer.podspec +31 -0
- package/README.md +610 -0
- package/android/CMakeLists.txt +29 -0
- package/android/build.gradle +147 -0
- package/android/fix-prefab.gradle +51 -0
- package/android/gradle.properties +5 -0
- package/android/src/main/AndroidManifest.xml +2 -0
- package/android/src/main/cpp/cpp-adapter.cpp +7 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrary.kt +29 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAudioDevices.kt +116 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridPlayerQueue.kt +167 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridTrackPlayer.kt +93 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/NitroPlayerPackage.kt +21 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/connection/AndroidAutoConnectionDetector.kt +171 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/core/TrackPlayerCore.kt +639 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaBrowserService.kt +352 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibrary.kt +58 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibraryManager.kt +77 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaLibraryParser.kt +73 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaSessionManager.kt +506 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/Playlist.kt +21 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/PlaylistManager.kt +454 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/queue/Queue.kt +94 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/queue/QueueManager.kt +143 -0
- package/ios/HybridAudioRoutePicker.swift +53 -0
- package/ios/HybridTrackPlayer.swift +100 -0
- package/ios/core/TrackPlayerCore.swift +1040 -0
- package/ios/media/MediaSessionManager.swift +230 -0
- package/ios/playlist/PlaylistManager.swift +446 -0
- package/ios/playlist/PlaylistModel.swift +49 -0
- package/ios/queue/HybridPlayerQueue.swift +95 -0
- package/ios/queue/Queue.swift +126 -0
- package/ios/queue/QueueManager.swift +157 -0
- package/lib/hooks/index.d.ts +6 -0
- package/lib/hooks/index.js +6 -0
- package/lib/hooks/useAndroidAutoConnection.d.ts +13 -0
- package/lib/hooks/useAndroidAutoConnection.js +26 -0
- package/lib/hooks/useAudioDevices.d.ts +26 -0
- package/lib/hooks/useAudioDevices.js +55 -0
- package/lib/hooks/useOnChangeTrack.d.ts +9 -0
- package/lib/hooks/useOnChangeTrack.js +17 -0
- package/lib/hooks/useOnPlaybackProgressChange.d.ts +9 -0
- package/lib/hooks/useOnPlaybackProgressChange.js +19 -0
- package/lib/hooks/useOnPlaybackStateChange.d.ts +9 -0
- package/lib/hooks/useOnPlaybackStateChange.js +17 -0
- package/lib/hooks/useOnSeek.d.ts +8 -0
- package/lib/hooks/useOnSeek.js +17 -0
- package/lib/index.d.ts +14 -0
- package/lib/index.js +24 -0
- package/lib/specs/AndroidAutoMediaLibrary.nitro.d.ts +21 -0
- package/lib/specs/AndroidAutoMediaLibrary.nitro.js +1 -0
- package/lib/specs/AudioDevices.nitro.d.ts +24 -0
- package/lib/specs/AudioDevices.nitro.js +1 -0
- package/lib/specs/AudioRoutePicker.nitro.d.ts +10 -0
- package/lib/specs/AudioRoutePicker.nitro.js +1 -0
- package/lib/specs/TrackPlayer.nitro.d.ts +39 -0
- package/lib/specs/TrackPlayer.nitro.js +1 -0
- package/lib/types/AndroidAutoMediaLibrary.d.ts +44 -0
- package/lib/types/AndroidAutoMediaLibrary.js +1 -0
- package/lib/types/PlayerQueue.d.ts +32 -0
- package/lib/types/PlayerQueue.js +1 -0
- package/lib/utils/androidAutoMediaLibrary.d.ts +47 -0
- package/lib/utils/androidAutoMediaLibrary.js +62 -0
- package/nitro.json +31 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/android/NitroPlayer+autolinking.cmake +91 -0
- package/nitrogen/generated/android/NitroPlayer+autolinking.gradle +27 -0
- package/nitrogen/generated/android/NitroPlayerOnLoad.cpp +88 -0
- package/nitrogen/generated/android/NitroPlayerOnLoad.hpp +25 -0
- package/nitrogen/generated/android/c++/JFunc_void_TrackItem_std__optional_Reason_.hpp +85 -0
- package/nitrogen/generated/android/c++/JFunc_void_TrackPlayerState_std__optional_Reason_.hpp +80 -0
- package/nitrogen/generated/android/c++/JFunc_void_bool.hpp +75 -0
- package/nitrogen/generated/android/c++/JFunc_void_double_double.hpp +75 -0
- package/nitrogen/generated/android/c++/JFunc_void_double_double_std__optional_bool_.hpp +76 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__string_Playlist_std__optional_QueueOperation_.hpp +88 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__vector_Playlist__std__optional_QueueOperation_.hpp +106 -0
- package/nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.cpp +55 -0
- package/nitrogen/generated/android/c++/JHybridAndroidAutoMediaLibrarySpec.hpp +66 -0
- package/nitrogen/generated/android/c++/JHybridAudioDevicesSpec.cpp +70 -0
- package/nitrogen/generated/android/c++/JHybridAudioDevicesSpec.hpp +66 -0
- package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.cpp +143 -0
- package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.hpp +77 -0
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp +137 -0
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.hpp +78 -0
- package/nitrogen/generated/android/c++/JPlayerConfig.hpp +65 -0
- package/nitrogen/generated/android/c++/JPlayerState.hpp +87 -0
- package/nitrogen/generated/android/c++/JPlaylist.hpp +99 -0
- package/nitrogen/generated/android/c++/JQueueOperation.hpp +65 -0
- package/nitrogen/generated/android/c++/JReason.hpp +65 -0
- package/nitrogen/generated/android/c++/JTAudioDevice.hpp +69 -0
- package/nitrogen/generated/android/c++/JTrackItem.hpp +86 -0
- package/nitrogen/generated/android/c++/JTrackPlayerState.hpp +62 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.hpp +77 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_String.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_String.hpp +70 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.hpp +74 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_TrackItem_std__optional_Reason_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_TrackPlayerState_std__optional_Reason_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_bool.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_double_double.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_double_double_std__optional_bool_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__string_Playlist_std__optional_QueueOperation_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__vector_Playlist__std__optional_QueueOperation_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrarySpec.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridAudioDevicesSpec.kt +61 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridPlayerQueueSpec.kt +116 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt +134 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/NitroPlayerOnLoad.kt +35 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerConfig.kt +44 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerState.kt +53 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Playlist.kt +50 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/QueueOperation.kt +23 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Reason.kt +23 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TAudioDevice.kt +47 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackItem.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackPlayerState.kt +22 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_Playlist.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_String.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_TrackItem.kt +59 -0
- package/nitrogen/generated/ios/NitroPlayer+autolinking.rb +60 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.cpp +123 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.hpp +531 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Umbrella.hpp +80 -0
- package/nitrogen/generated/ios/NitroPlayerAutolinking.mm +49 -0
- package/nitrogen/generated/ios/NitroPlayerAutolinking.swift +55 -0
- package/nitrogen/generated/ios/c++/HybridAudioRoutePickerSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridAudioRoutePickerSpecSwift.hpp +74 -0
- package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.hpp +167 -0
- package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.hpp +174 -0
- package/nitrogen/generated/ios/swift/Func_void_TrackItem_std__optional_Reason_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_TrackPlayerState_std__optional_Reason_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_bool.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_double_double.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_double_double_std__optional_bool_.swift +54 -0
- package/nitrogen/generated/ios/swift/Func_void_std__string_Playlist_std__optional_QueueOperation_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_Playlist__std__optional_QueueOperation_.swift +47 -0
- package/nitrogen/generated/ios/swift/HybridAudioRoutePickerSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/HybridAudioRoutePickerSpec_cxx.swift +130 -0
- package/nitrogen/generated/ios/swift/HybridPlayerQueueSpec.swift +68 -0
- package/nitrogen/generated/ios/swift/HybridPlayerQueueSpec_cxx.swift +349 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec.swift +69 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec_cxx.swift +325 -0
- package/nitrogen/generated/ios/swift/PlayerConfig.swift +115 -0
- package/nitrogen/generated/ios/swift/PlayerState.swift +181 -0
- package/nitrogen/generated/ios/swift/Playlist.swift +182 -0
- package/nitrogen/generated/ios/swift/QueueOperation.swift +48 -0
- package/nitrogen/generated/ios/swift/Reason.swift +48 -0
- package/nitrogen/generated/ios/swift/TrackItem.swift +147 -0
- package/nitrogen/generated/ios/swift/TrackPlayerState.swift +44 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_Playlist.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_String.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_TrackItem.swift +18 -0
- package/nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridAndroidAutoMediaLibrarySpec.hpp +63 -0
- package/nitrogen/generated/shared/c++/HybridAudioDevicesSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridAudioDevicesSpec.hpp +65 -0
- package/nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.cpp +21 -0
- package/nitrogen/generated/shared/c++/HybridAudioRoutePickerSpec.hpp +62 -0
- package/nitrogen/generated/shared/c++/HybridPlayerQueueSpec.cpp +33 -0
- package/nitrogen/generated/shared/c++/HybridPlayerQueueSpec.hpp +87 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp +34 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.hpp +91 -0
- package/nitrogen/generated/shared/c++/PlayerConfig.hpp +83 -0
- package/nitrogen/generated/shared/c++/PlayerState.hpp +103 -0
- package/nitrogen/generated/shared/c++/Playlist.hpp +97 -0
- package/nitrogen/generated/shared/c++/QueueOperation.hpp +84 -0
- package/nitrogen/generated/shared/c++/Reason.hpp +84 -0
- package/nitrogen/generated/shared/c++/TAudioDevice.hpp +87 -0
- package/nitrogen/generated/shared/c++/TrackItem.hpp +102 -0
- package/nitrogen/generated/shared/c++/TrackPlayerState.hpp +80 -0
- package/package.json +172 -0
- package/react-native.config.js +16 -0
- package/src/hooks/index.ts +6 -0
- package/src/hooks/useAndroidAutoConnection.ts +30 -0
- package/src/hooks/useAudioDevices.ts +64 -0
- package/src/hooks/useOnChangeTrack.ts +24 -0
- package/src/hooks/useOnPlaybackProgressChange.ts +30 -0
- package/src/hooks/useOnPlaybackStateChange.ts +24 -0
- package/src/hooks/useOnSeek.ts +25 -0
- package/src/index.ts +47 -0
- package/src/specs/AndroidAutoMediaLibrary.nitro.ts +22 -0
- package/src/specs/AudioDevices.nitro.ts +25 -0
- package/src/specs/AudioRoutePicker.nitro.ts +9 -0
- package/src/specs/TrackPlayer.nitro.ts +81 -0
- package/src/types/AndroidAutoMediaLibrary.ts +58 -0
- package/src/types/PlayerQueue.ts +38 -0
- package/src/utils/androidAutoMediaLibrary.ts +66 -0
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
|
+
}
|