react-native-nitro-player 0.3.0-alpha.9 → 0.4.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.
- package/README.md +444 -4
- package/android/build.gradle +4 -1
- package/android/src/main/AndroidManifest.xml +16 -1
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAndroidAutoMediaLibrary.kt +2 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridAudioDevices.kt +8 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridDownloadManager.kt +225 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridEqualizer.kt +105 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridPlayerQueue.kt +6 -6
- package/android/src/main/java/com/margelo/nitro/nitroplayer/HybridTrackPlayer.kt +37 -12
- package/android/src/main/java/com/margelo/nitro/nitroplayer/core/TrackPlayerCore.kt +970 -213
- package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadDatabase.kt +475 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadFileManager.kt +159 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadManagerCore.kt +489 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/download/DownloadWorker.kt +209 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/equalizer/EqualizerCore.kt +486 -0
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaBrowserService.kt +3 -1
- package/android/src/main/java/com/margelo/nitro/nitroplayer/media/MediaSessionManager.kt +14 -6
- package/android/src/main/java/com/margelo/nitro/nitroplayer/playlist/PlaylistManager.kt +27 -0
- package/ios/HybridDownloadManager.swift +226 -0
- package/ios/HybridEqualizer.swift +111 -0
- package/ios/HybridTrackPlayer.swift +36 -8
- package/ios/core/TrackPlayerCore.swift +998 -276
- package/ios/download/DownloadDatabase.swift +493 -0
- package/ios/download/DownloadFileManager.swift +241 -0
- package/ios/download/DownloadManagerCore.swift +923 -0
- package/ios/equalizer/EqualizerCore.swift +685 -0
- package/ios/media/MediaSessionManager.swift +40 -28
- package/ios/playlist/PlaylistManager.swift +40 -9
- package/ios/queue/HybridPlayerQueue.swift +33 -13
- package/lib/hooks/downloadCallbackManager.d.ts +36 -0
- package/lib/hooks/downloadCallbackManager.js +108 -0
- package/lib/hooks/equalizerCallbackManager.d.ts +37 -0
- package/lib/hooks/equalizerCallbackManager.js +109 -0
- package/lib/hooks/index.d.ts +16 -0
- package/lib/hooks/index.js +10 -0
- package/lib/hooks/useActualQueue.d.ts +48 -0
- package/lib/hooks/useActualQueue.js +98 -0
- package/lib/hooks/useDownloadActions.d.ts +26 -0
- package/lib/hooks/useDownloadActions.js +117 -0
- package/lib/hooks/useDownloadProgress.d.ts +25 -0
- package/lib/hooks/useDownloadProgress.js +79 -0
- package/lib/hooks/useDownloadStorage.d.ts +19 -0
- package/lib/hooks/useDownloadStorage.js +60 -0
- package/lib/hooks/useDownloadedTracks.d.ts +25 -0
- package/lib/hooks/useDownloadedTracks.js +69 -0
- package/lib/hooks/useEqualizer.d.ts +25 -0
- package/lib/hooks/useEqualizer.js +124 -0
- package/lib/hooks/useEqualizerPresets.d.ts +22 -0
- package/lib/hooks/useEqualizerPresets.js +96 -0
- package/lib/hooks/useNowPlaying.js +3 -2
- package/lib/hooks/useOnChangeTrack.js +15 -12
- package/lib/hooks/useOnPlaybackStateChange.js +16 -13
- package/lib/hooks/usePlaylist.d.ts +48 -0
- package/lib/hooks/usePlaylist.js +136 -0
- package/lib/index.d.ts +6 -0
- package/lib/index.js +6 -0
- package/lib/specs/DownloadManager.nitro.d.ts +152 -0
- package/lib/specs/DownloadManager.nitro.js +1 -0
- package/lib/specs/Equalizer.nitro.d.ts +43 -0
- package/lib/specs/Equalizer.nitro.js +1 -0
- package/lib/specs/TrackPlayer.nitro.d.ts +6 -2
- package/lib/types/DownloadTypes.d.ts +110 -0
- package/lib/types/DownloadTypes.js +1 -0
- package/lib/types/EqualizerTypes.d.ts +52 -0
- package/lib/types/EqualizerTypes.js +1 -0
- package/lib/types/PlayerQueue.d.ts +4 -0
- package/nitro.json +8 -0
- package/nitrogen/generated/android/NitroPlayer+autolinking.cmake +10 -1
- package/nitrogen/generated/android/NitroPlayerOnLoad.cpp +32 -2
- package/nitrogen/generated/android/c++/JCurrentPlayingType.hpp +65 -0
- package/nitrogen/generated/android/c++/JDownloadConfig.hpp +92 -0
- package/nitrogen/generated/android/c++/JDownloadError.hpp +71 -0
- package/nitrogen/generated/android/c++/JDownloadErrorReason.hpp +74 -0
- package/nitrogen/generated/android/c++/JDownloadProgress.hpp +79 -0
- package/nitrogen/generated/android/c++/JDownloadQueueStatus.hpp +81 -0
- package/nitrogen/generated/android/c++/JDownloadState.hpp +71 -0
- package/nitrogen/generated/android/c++/JDownloadStorageInfo.hpp +73 -0
- package/nitrogen/generated/android/c++/JDownloadTask.hpp +108 -0
- package/nitrogen/generated/android/c++/JDownloadedPlaylist.hpp +111 -0
- package/nitrogen/generated/android/c++/JDownloadedTrack.hpp +92 -0
- package/nitrogen/generated/android/c++/JEqualizerBand.hpp +69 -0
- package/nitrogen/generated/android/c++/JEqualizerPreset.hpp +78 -0
- package/nitrogen/generated/android/c++/JEqualizerState.hpp +91 -0
- package/nitrogen/generated/android/c++/JFunc_void_DownloadProgress.hpp +80 -0
- package/nitrogen/generated/android/c++/JFunc_void_DownloadedTrack.hpp +89 -0
- package/nitrogen/generated/android/c++/JFunc_void_TrackItem_std__optional_Reason_.hpp +2 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__optional_std__variant_nitro__NullType__std__string__.hpp +81 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__string_Playlist_std__optional_QueueOperation_.hpp +2 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__string_std__string_DownloadState_std__optional_DownloadError_.hpp +83 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__vector_EqualizerBand_.hpp +97 -0
- package/nitrogen/generated/android/c++/JFunc_void_std__vector_Playlist__std__optional_QueueOperation_.hpp +2 -0
- package/nitrogen/generated/android/c++/JGainRange.hpp +61 -0
- package/nitrogen/generated/android/c++/JHybridDownloadManagerSpec.cpp +470 -0
- package/nitrogen/generated/android/c++/JHybridDownloadManagerSpec.hpp +99 -0
- package/nitrogen/generated/android/c++/JHybridEqualizerSpec.cpp +204 -0
- package/nitrogen/generated/android/c++/JHybridEqualizerSpec.hpp +82 -0
- package/nitrogen/generated/android/c++/JHybridPlayerQueueSpec.cpp +2 -0
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.cpp +117 -15
- package/nitrogen/generated/android/c++/JHybridTrackPlayerSpec.hpp +6 -2
- package/nitrogen/generated/android/c++/JPlaybackSource.hpp +62 -0
- package/nitrogen/generated/android/c++/JPlayerState.hpp +11 -3
- package/nitrogen/generated/android/c++/JPlaylist.hpp +2 -0
- package/nitrogen/generated/android/c++/JPresetType.hpp +59 -0
- package/nitrogen/generated/android/c++/JStorageLocation.hpp +59 -0
- package/nitrogen/generated/android/c++/JTrackItem.hpp +9 -3
- package/nitrogen/generated/android/c++/JTrackPlayerState.hpp +3 -3
- package/nitrogen/generated/android/c++/JVariant_NullType_Double.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Double.hpp +69 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadError.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadError.hpp +74 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadTask.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadTask.hpp +84 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedPlaylist.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedPlaylist.hpp +85 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedTrack.cpp +26 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_DownloadedTrack.hpp +80 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_Playlist.hpp +2 -0
- package/nitrogen/generated/android/c++/JVariant_NullType_TrackItem.hpp +2 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/CurrentPlayingType.kt +23 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadConfig.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadError.kt +47 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadErrorReason.kt +26 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadProgress.kt +53 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadQueueStatus.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadState.kt +25 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadStorageInfo.kt +50 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadTask.kt +65 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadedPlaylist.kt +53 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/DownloadedTrack.kt +56 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/EqualizerBand.kt +47 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/EqualizerPreset.kt +44 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/EqualizerState.kt +44 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_DownloadProgress.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_DownloadedTrack.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__optional_std__variant_nitro__NullType__std__string__.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__string_std__string_DownloadState_std__optional_DownloadError_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Func_void_std__vector_EqualizerBand_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/GainRange.kt +41 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridDownloadManagerSpec.kt +210 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridEqualizerSpec.kt +141 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/HybridTrackPlayerSpec.kt +19 -2
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlaybackSource.kt +22 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PlayerState.kt +6 -3
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/PresetType.kt +21 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/StorageLocation.kt +21 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackItem.kt +7 -3
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/TrackPlayerState.kt +2 -2
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_Double.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadError.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadTask.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadedPlaylist.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitroplayer/Variant_NullType_DownloadedTrack.kt +59 -0
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.cpp +138 -8
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Bridge.hpp +1046 -121
- package/nitrogen/generated/ios/NitroPlayer-Swift-Cxx-Umbrella.hpp +66 -0
- package/nitrogen/generated/ios/NitroPlayerAutolinking.mm +16 -0
- package/nitrogen/generated/ios/NitroPlayerAutolinking.swift +30 -0
- package/nitrogen/generated/ios/c++/HybridDownloadManagerSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridDownloadManagerSpecSwift.hpp +386 -0
- package/nitrogen/generated/ios/c++/HybridEqualizerSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridEqualizerSpecSwift.hpp +223 -0
- package/nitrogen/generated/ios/c++/HybridPlayerQueueSpecSwift.hpp +1 -0
- package/nitrogen/generated/ios/c++/HybridTrackPlayerSpecSwift.hpp +46 -6
- package/nitrogen/generated/ios/swift/CurrentPlayingType.swift +48 -0
- package/nitrogen/generated/ios/swift/DownloadConfig.swift +270 -0
- package/nitrogen/generated/ios/swift/DownloadError.swift +69 -0
- package/nitrogen/generated/ios/swift/DownloadErrorReason.swift +60 -0
- package/nitrogen/generated/ios/swift/DownloadProgress.swift +91 -0
- package/nitrogen/generated/ios/swift/DownloadQueueStatus.swift +102 -0
- package/nitrogen/generated/ios/swift/DownloadState.swift +56 -0
- package/nitrogen/generated/ios/swift/DownloadStorageInfo.swift +80 -0
- package/nitrogen/generated/ios/swift/DownloadTask.swift +315 -0
- package/nitrogen/generated/ios/swift/DownloadedPlaylist.swift +103 -0
- package/nitrogen/generated/ios/swift/DownloadedTrack.swift +147 -0
- package/nitrogen/generated/ios/swift/EqualizerBand.swift +69 -0
- package/nitrogen/generated/ios/swift/EqualizerPreset.swift +70 -0
- package/nitrogen/generated/ios/swift/EqualizerState.swift +115 -0
- package/nitrogen/generated/ios/swift/Func_void.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_DownloadProgress.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_DownloadStorageInfo.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_DownloadedTrack.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_PlayerState.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_bool.swift +5 -5
- package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__optional_std__variant_nitro__NullType__std__string__.swift +66 -0
- package/nitrogen/generated/ios/swift/Func_void_std__string.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__string_std__string_DownloadState_std__optional_DownloadError_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_EqualizerBand_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_TrackItem_.swift +47 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_std__string_.swift +47 -0
- package/nitrogen/generated/ios/swift/GainRange.swift +47 -0
- package/nitrogen/generated/ios/swift/HybridDownloadManagerSpec.swift +90 -0
- package/nitrogen/generated/ios/swift/HybridDownloadManagerSpec_cxx.swift +705 -0
- package/nitrogen/generated/ios/swift/HybridEqualizerSpec.swift +73 -0
- package/nitrogen/generated/ios/swift/HybridEqualizerSpec_cxx.swift +396 -0
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec.swift +6 -2
- package/nitrogen/generated/ios/swift/HybridTrackPlayerSpec_cxx.swift +105 -8
- package/nitrogen/generated/ios/swift/PlaybackSource.swift +44 -0
- package/nitrogen/generated/ios/swift/PlayerState.swift +13 -2
- package/nitrogen/generated/ios/swift/PresetType.swift +40 -0
- package/nitrogen/generated/ios/swift/StorageLocation.swift +40 -0
- package/nitrogen/generated/ios/swift/TrackItem.swift +31 -1
- package/nitrogen/generated/ios/swift/TrackPlayerState.swift +4 -4
- package/nitrogen/generated/ios/swift/Variant_NullType_Double.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_DownloadError.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_DownloadTask.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_DownloadedPlaylist.swift +18 -0
- package/nitrogen/generated/ios/swift/Variant_NullType_DownloadedTrack.swift +18 -0
- package/nitrogen/generated/shared/c++/CurrentPlayingType.hpp +84 -0
- package/nitrogen/generated/shared/c++/DownloadConfig.hpp +108 -0
- package/nitrogen/generated/shared/c++/DownloadError.hpp +89 -0
- package/nitrogen/generated/shared/c++/DownloadErrorReason.hpp +96 -0
- package/nitrogen/generated/shared/c++/DownloadProgress.hpp +97 -0
- package/nitrogen/generated/shared/c++/DownloadQueueStatus.hpp +99 -0
- package/nitrogen/generated/shared/c++/DownloadState.hpp +92 -0
- package/nitrogen/generated/shared/c++/DownloadStorageInfo.hpp +91 -0
- package/nitrogen/generated/shared/c++/DownloadTask.hpp +122 -0
- package/nitrogen/generated/shared/c++/DownloadedPlaylist.hpp +101 -0
- package/nitrogen/generated/shared/c++/DownloadedTrack.hpp +107 -0
- package/nitrogen/generated/shared/c++/EqualizerBand.hpp +87 -0
- package/nitrogen/generated/shared/c++/EqualizerPreset.hpp +86 -0
- package/nitrogen/generated/shared/c++/EqualizerState.hpp +89 -0
- package/nitrogen/generated/shared/c++/GainRange.hpp +79 -0
- package/nitrogen/generated/shared/c++/HybridDownloadManagerSpec.cpp +55 -0
- package/nitrogen/generated/shared/c++/HybridDownloadManagerSpec.hpp +134 -0
- package/nitrogen/generated/shared/c++/HybridEqualizerSpec.cpp +38 -0
- package/nitrogen/generated/shared/c++/HybridEqualizerSpec.hpp +95 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.cpp +4 -0
- package/nitrogen/generated/shared/c++/HybridTrackPlayerSpec.hpp +11 -5
- package/nitrogen/generated/shared/c++/PlaybackSource.hpp +80 -0
- package/nitrogen/generated/shared/c++/PlayerState.hpp +9 -2
- package/nitrogen/generated/shared/c++/PresetType.hpp +76 -0
- package/nitrogen/generated/shared/c++/StorageLocation.hpp +76 -0
- package/nitrogen/generated/shared/c++/TrackItem.hpp +7 -2
- package/nitrogen/generated/shared/c++/TrackPlayerState.hpp +5 -5
- package/package.json +1 -1
- package/src/hooks/downloadCallbackManager.ts +149 -0
- package/src/hooks/equalizerCallbackManager.ts +138 -0
- package/src/hooks/index.ts +23 -0
- package/src/hooks/useActualQueue.ts +116 -0
- package/src/hooks/useDownloadActions.ts +179 -0
- package/src/hooks/useDownloadProgress.ts +126 -0
- package/src/hooks/useDownloadStorage.ts +84 -0
- package/src/hooks/useDownloadedTracks.ts +138 -0
- package/src/hooks/useEqualizer.ts +173 -0
- package/src/hooks/useEqualizerPresets.ts +140 -0
- package/src/hooks/useNowPlaying.ts +3 -2
- package/src/hooks/useOnChangeTrack.ts +15 -11
- package/src/hooks/useOnPlaybackStateChange.ts +19 -15
- package/src/hooks/usePlaylist.ts +161 -0
- package/src/index.ts +12 -0
- package/src/specs/DownloadManager.nitro.ts +203 -0
- package/src/specs/Equalizer.nitro.ts +69 -0
- package/src/specs/TrackPlayer.nitro.ts +6 -2
- package/src/types/DownloadTypes.ts +135 -0
- package/src/types/EqualizerTypes.ts +72 -0
- package/src/types/PlayerQueue.ts +9 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridEqualizerSpec.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridEqualizerSpec.hpp"
|
|
9
|
+
|
|
10
|
+
namespace margelo::nitro::nitroplayer {
|
|
11
|
+
|
|
12
|
+
void HybridEqualizerSpec::loadHybridMethods() {
|
|
13
|
+
// load base methods/properties
|
|
14
|
+
HybridObject::loadHybridMethods();
|
|
15
|
+
// load custom methods/properties
|
|
16
|
+
registerHybrids(this, [](Prototype& prototype) {
|
|
17
|
+
prototype.registerHybridMethod("setEnabled", &HybridEqualizerSpec::setEnabled);
|
|
18
|
+
prototype.registerHybridMethod("isEnabled", &HybridEqualizerSpec::isEnabled);
|
|
19
|
+
prototype.registerHybridMethod("getBands", &HybridEqualizerSpec::getBands);
|
|
20
|
+
prototype.registerHybridMethod("setBandGain", &HybridEqualizerSpec::setBandGain);
|
|
21
|
+
prototype.registerHybridMethod("setAllBandGains", &HybridEqualizerSpec::setAllBandGains);
|
|
22
|
+
prototype.registerHybridMethod("getBandRange", &HybridEqualizerSpec::getBandRange);
|
|
23
|
+
prototype.registerHybridMethod("getPresets", &HybridEqualizerSpec::getPresets);
|
|
24
|
+
prototype.registerHybridMethod("getBuiltInPresets", &HybridEqualizerSpec::getBuiltInPresets);
|
|
25
|
+
prototype.registerHybridMethod("getCustomPresets", &HybridEqualizerSpec::getCustomPresets);
|
|
26
|
+
prototype.registerHybridMethod("applyPreset", &HybridEqualizerSpec::applyPreset);
|
|
27
|
+
prototype.registerHybridMethod("getCurrentPresetName", &HybridEqualizerSpec::getCurrentPresetName);
|
|
28
|
+
prototype.registerHybridMethod("saveCustomPreset", &HybridEqualizerSpec::saveCustomPreset);
|
|
29
|
+
prototype.registerHybridMethod("deleteCustomPreset", &HybridEqualizerSpec::deleteCustomPreset);
|
|
30
|
+
prototype.registerHybridMethod("getState", &HybridEqualizerSpec::getState);
|
|
31
|
+
prototype.registerHybridMethod("reset", &HybridEqualizerSpec::reset);
|
|
32
|
+
prototype.registerHybridMethod("onEnabledChange", &HybridEqualizerSpec::onEnabledChange);
|
|
33
|
+
prototype.registerHybridMethod("onBandChange", &HybridEqualizerSpec::onBandChange);
|
|
34
|
+
prototype.registerHybridMethod("onPresetChange", &HybridEqualizerSpec::onPresetChange);
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
} // namespace margelo::nitro::nitroplayer
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridEqualizerSpec.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/HybridObject.hpp>)
|
|
11
|
+
#include <NitroModules/HybridObject.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
|
|
16
|
+
// Forward declaration of `EqualizerBand` to properly resolve imports.
|
|
17
|
+
namespace margelo::nitro::nitroplayer { struct EqualizerBand; }
|
|
18
|
+
// Forward declaration of `GainRange` to properly resolve imports.
|
|
19
|
+
namespace margelo::nitro::nitroplayer { struct GainRange; }
|
|
20
|
+
// Forward declaration of `EqualizerPreset` to properly resolve imports.
|
|
21
|
+
namespace margelo::nitro::nitroplayer { struct EqualizerPreset; }
|
|
22
|
+
// Forward declaration of `EqualizerState` to properly resolve imports.
|
|
23
|
+
namespace margelo::nitro::nitroplayer { struct EqualizerState; }
|
|
24
|
+
|
|
25
|
+
#include "EqualizerBand.hpp"
|
|
26
|
+
#include <vector>
|
|
27
|
+
#include "GainRange.hpp"
|
|
28
|
+
#include "EqualizerPreset.hpp"
|
|
29
|
+
#include <string>
|
|
30
|
+
#include <NitroModules/Null.hpp>
|
|
31
|
+
#include <variant>
|
|
32
|
+
#include "EqualizerState.hpp"
|
|
33
|
+
#include <functional>
|
|
34
|
+
#include <optional>
|
|
35
|
+
|
|
36
|
+
namespace margelo::nitro::nitroplayer {
|
|
37
|
+
|
|
38
|
+
using namespace margelo::nitro;
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* An abstract base class for `Equalizer`
|
|
42
|
+
* Inherit this class to create instances of `HybridEqualizerSpec` in C++.
|
|
43
|
+
* You must explicitly call `HybridObject`'s constructor yourself, because it is virtual.
|
|
44
|
+
* @example
|
|
45
|
+
* ```cpp
|
|
46
|
+
* class HybridEqualizer: public HybridEqualizerSpec {
|
|
47
|
+
* public:
|
|
48
|
+
* HybridEqualizer(...): HybridObject(TAG) { ... }
|
|
49
|
+
* // ...
|
|
50
|
+
* };
|
|
51
|
+
* ```
|
|
52
|
+
*/
|
|
53
|
+
class HybridEqualizerSpec: public virtual HybridObject {
|
|
54
|
+
public:
|
|
55
|
+
// Constructor
|
|
56
|
+
explicit HybridEqualizerSpec(): HybridObject(TAG) { }
|
|
57
|
+
|
|
58
|
+
// Destructor
|
|
59
|
+
~HybridEqualizerSpec() override = default;
|
|
60
|
+
|
|
61
|
+
public:
|
|
62
|
+
// Properties
|
|
63
|
+
|
|
64
|
+
|
|
65
|
+
public:
|
|
66
|
+
// Methods
|
|
67
|
+
virtual bool setEnabled(bool enabled) = 0;
|
|
68
|
+
virtual bool isEnabled() = 0;
|
|
69
|
+
virtual std::vector<EqualizerBand> getBands() = 0;
|
|
70
|
+
virtual bool setBandGain(double bandIndex, double gainDb) = 0;
|
|
71
|
+
virtual bool setAllBandGains(const std::vector<double>& gains) = 0;
|
|
72
|
+
virtual GainRange getBandRange() = 0;
|
|
73
|
+
virtual std::vector<EqualizerPreset> getPresets() = 0;
|
|
74
|
+
virtual std::vector<EqualizerPreset> getBuiltInPresets() = 0;
|
|
75
|
+
virtual std::vector<EqualizerPreset> getCustomPresets() = 0;
|
|
76
|
+
virtual bool applyPreset(const std::string& presetName) = 0;
|
|
77
|
+
virtual std::variant<nitro::NullType, std::string> getCurrentPresetName() = 0;
|
|
78
|
+
virtual bool saveCustomPreset(const std::string& name) = 0;
|
|
79
|
+
virtual bool deleteCustomPreset(const std::string& name) = 0;
|
|
80
|
+
virtual EqualizerState getState() = 0;
|
|
81
|
+
virtual void reset() = 0;
|
|
82
|
+
virtual void onEnabledChange(const std::function<void(bool /* enabled */)>& callback) = 0;
|
|
83
|
+
virtual void onBandChange(const std::function<void(const std::vector<EqualizerBand>& /* bands */)>& callback) = 0;
|
|
84
|
+
virtual void onPresetChange(const std::function<void(const std::optional<std::variant<nitro::NullType, std::string>>& /* presetName */)>& callback) = 0;
|
|
85
|
+
|
|
86
|
+
protected:
|
|
87
|
+
// Hybrid Setup
|
|
88
|
+
void loadHybridMethods() override;
|
|
89
|
+
|
|
90
|
+
protected:
|
|
91
|
+
// Tag for logging
|
|
92
|
+
static constexpr auto TAG = "Equalizer";
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
} // namespace margelo::nitro::nitroplayer
|
|
@@ -18,8 +18,12 @@ namespace margelo::nitro::nitroplayer {
|
|
|
18
18
|
prototype.registerHybridMethod("pause", &HybridTrackPlayerSpec::pause);
|
|
19
19
|
prototype.registerHybridMethod("playSong", &HybridTrackPlayerSpec::playSong);
|
|
20
20
|
prototype.registerHybridMethod("skipToNext", &HybridTrackPlayerSpec::skipToNext);
|
|
21
|
+
prototype.registerHybridMethod("skipToIndex", &HybridTrackPlayerSpec::skipToIndex);
|
|
21
22
|
prototype.registerHybridMethod("skipToPrevious", &HybridTrackPlayerSpec::skipToPrevious);
|
|
22
23
|
prototype.registerHybridMethod("seek", &HybridTrackPlayerSpec::seek);
|
|
24
|
+
prototype.registerHybridMethod("addToUpNext", &HybridTrackPlayerSpec::addToUpNext);
|
|
25
|
+
prototype.registerHybridMethod("playNext", &HybridTrackPlayerSpec::playNext);
|
|
26
|
+
prototype.registerHybridMethod("getActualQueue", &HybridTrackPlayerSpec::getActualQueue);
|
|
23
27
|
prototype.registerHybridMethod("getState", &HybridTrackPlayerSpec::getState);
|
|
24
28
|
prototype.registerHybridMethod("setRepeatMode", &HybridTrackPlayerSpec::setRepeatMode);
|
|
25
29
|
prototype.registerHybridMethod("configure", &HybridTrackPlayerSpec::configure);
|
|
@@ -13,25 +13,27 @@
|
|
|
13
13
|
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
14
|
#endif
|
|
15
15
|
|
|
16
|
+
// Forward declaration of `TrackItem` to properly resolve imports.
|
|
17
|
+
namespace margelo::nitro::nitroplayer { struct TrackItem; }
|
|
16
18
|
// Forward declaration of `PlayerState` to properly resolve imports.
|
|
17
19
|
namespace margelo::nitro::nitroplayer { struct PlayerState; }
|
|
18
20
|
// Forward declaration of `RepeatMode` to properly resolve imports.
|
|
19
21
|
namespace margelo::nitro::nitroplayer { enum class RepeatMode; }
|
|
20
22
|
// Forward declaration of `PlayerConfig` to properly resolve imports.
|
|
21
23
|
namespace margelo::nitro::nitroplayer { struct PlayerConfig; }
|
|
22
|
-
// Forward declaration of `TrackItem` to properly resolve imports.
|
|
23
|
-
namespace margelo::nitro::nitroplayer { struct TrackItem; }
|
|
24
24
|
// Forward declaration of `Reason` to properly resolve imports.
|
|
25
25
|
namespace margelo::nitro::nitroplayer { enum class Reason; }
|
|
26
26
|
// Forward declaration of `TrackPlayerState` to properly resolve imports.
|
|
27
27
|
namespace margelo::nitro::nitroplayer { enum class TrackPlayerState; }
|
|
28
28
|
|
|
29
|
+
#include <NitroModules/Promise.hpp>
|
|
29
30
|
#include <string>
|
|
30
31
|
#include <optional>
|
|
32
|
+
#include "TrackItem.hpp"
|
|
33
|
+
#include <vector>
|
|
31
34
|
#include "PlayerState.hpp"
|
|
32
35
|
#include "RepeatMode.hpp"
|
|
33
36
|
#include "PlayerConfig.hpp"
|
|
34
|
-
#include "TrackItem.hpp"
|
|
35
37
|
#include "Reason.hpp"
|
|
36
38
|
#include <functional>
|
|
37
39
|
#include "TrackPlayerState.hpp"
|
|
@@ -69,11 +71,15 @@ namespace margelo::nitro::nitroplayer {
|
|
|
69
71
|
// Methods
|
|
70
72
|
virtual void play() = 0;
|
|
71
73
|
virtual void pause() = 0;
|
|
72
|
-
virtual void playSong(const std::string& songId, const std::optional<std::string>& fromPlaylist) = 0;
|
|
74
|
+
virtual std::shared_ptr<Promise<void>> playSong(const std::string& songId, const std::optional<std::string>& fromPlaylist) = 0;
|
|
73
75
|
virtual void skipToNext() = 0;
|
|
76
|
+
virtual std::shared_ptr<Promise<bool>> skipToIndex(double index) = 0;
|
|
74
77
|
virtual void skipToPrevious() = 0;
|
|
75
78
|
virtual void seek(double position) = 0;
|
|
76
|
-
virtual
|
|
79
|
+
virtual std::shared_ptr<Promise<void>> addToUpNext(const std::string& trackId) = 0;
|
|
80
|
+
virtual std::shared_ptr<Promise<void>> playNext(const std::string& trackId) = 0;
|
|
81
|
+
virtual std::shared_ptr<Promise<std::vector<TrackItem>>> getActualQueue() = 0;
|
|
82
|
+
virtual std::shared_ptr<Promise<PlayerState>> getState() = 0;
|
|
77
83
|
virtual bool setRepeatMode(RepeatMode mode) = 0;
|
|
78
84
|
virtual void configure(const PlayerConfig& config) = 0;
|
|
79
85
|
virtual void onChangeTrack(const std::function<void(const TrackItem& /* track */, std::optional<Reason> /* reason */)>& callback) = 0;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// PlaybackSource.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/NitroHash.hpp>)
|
|
11
|
+
#include <NitroModules/NitroHash.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
#if __has_include(<NitroModules/JSIConverter.hpp>)
|
|
16
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
17
|
+
#else
|
|
18
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
19
|
+
#endif
|
|
20
|
+
#if __has_include(<NitroModules/NitroDefines.hpp>)
|
|
21
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
22
|
+
#else
|
|
23
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::nitroplayer {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An enum which can be represented as a JavaScript union (PlaybackSource).
|
|
30
|
+
*/
|
|
31
|
+
enum class PlaybackSource {
|
|
32
|
+
AUTO SWIFT_NAME(auto) = 0,
|
|
33
|
+
DOWNLOAD SWIFT_NAME(download) = 1,
|
|
34
|
+
NETWORK SWIFT_NAME(network) = 2,
|
|
35
|
+
} CLOSED_ENUM;
|
|
36
|
+
|
|
37
|
+
} // namespace margelo::nitro::nitroplayer
|
|
38
|
+
|
|
39
|
+
namespace margelo::nitro {
|
|
40
|
+
|
|
41
|
+
// C++ PlaybackSource <> JS PlaybackSource (union)
|
|
42
|
+
template <>
|
|
43
|
+
struct JSIConverter<margelo::nitro::nitroplayer::PlaybackSource> final {
|
|
44
|
+
static inline margelo::nitro::nitroplayer::PlaybackSource fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
45
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
46
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
47
|
+
case hashString("auto"): return margelo::nitro::nitroplayer::PlaybackSource::AUTO;
|
|
48
|
+
case hashString("download"): return margelo::nitro::nitroplayer::PlaybackSource::DOWNLOAD;
|
|
49
|
+
case hashString("network"): return margelo::nitro::nitroplayer::PlaybackSource::NETWORK;
|
|
50
|
+
default: [[unlikely]]
|
|
51
|
+
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum PlaybackSource - invalid value!");
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::nitroplayer::PlaybackSource arg) {
|
|
55
|
+
switch (arg) {
|
|
56
|
+
case margelo::nitro::nitroplayer::PlaybackSource::AUTO: return JSIConverter<std::string>::toJSI(runtime, "auto");
|
|
57
|
+
case margelo::nitro::nitroplayer::PlaybackSource::DOWNLOAD: return JSIConverter<std::string>::toJSI(runtime, "download");
|
|
58
|
+
case margelo::nitro::nitroplayer::PlaybackSource::NETWORK: return JSIConverter<std::string>::toJSI(runtime, "network");
|
|
59
|
+
default: [[unlikely]]
|
|
60
|
+
throw std::invalid_argument("Cannot convert PlaybackSource to JS - invalid value: "
|
|
61
|
+
+ std::to_string(static_cast<int>(arg)) + "!");
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
65
|
+
if (!value.isString()) {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
69
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
70
|
+
case hashString("auto"):
|
|
71
|
+
case hashString("download"):
|
|
72
|
+
case hashString("network"):
|
|
73
|
+
return true;
|
|
74
|
+
default:
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
} // namespace margelo::nitro
|
|
@@ -27,6 +27,8 @@
|
|
|
27
27
|
namespace margelo::nitro::nitroplayer { struct TrackItem; }
|
|
28
28
|
// Forward declaration of `TrackPlayerState` to properly resolve imports.
|
|
29
29
|
namespace margelo::nitro::nitroplayer { enum class TrackPlayerState; }
|
|
30
|
+
// Forward declaration of `CurrentPlayingType` to properly resolve imports.
|
|
31
|
+
namespace margelo::nitro::nitroplayer { enum class CurrentPlayingType; }
|
|
30
32
|
|
|
31
33
|
#include <NitroModules/Null.hpp>
|
|
32
34
|
#include "TrackItem.hpp"
|
|
@@ -34,6 +36,7 @@ namespace margelo::nitro::nitroplayer { enum class TrackPlayerState; }
|
|
|
34
36
|
#include <optional>
|
|
35
37
|
#include "TrackPlayerState.hpp"
|
|
36
38
|
#include <string>
|
|
39
|
+
#include "CurrentPlayingType.hpp"
|
|
37
40
|
|
|
38
41
|
namespace margelo::nitro::nitroplayer {
|
|
39
42
|
|
|
@@ -48,10 +51,11 @@ namespace margelo::nitro::nitroplayer {
|
|
|
48
51
|
TrackPlayerState currentState SWIFT_PRIVATE;
|
|
49
52
|
std::optional<std::variant<nitro::NullType, std::string>> currentPlaylistId SWIFT_PRIVATE;
|
|
50
53
|
double currentIndex SWIFT_PRIVATE;
|
|
54
|
+
CurrentPlayingType currentPlayingType SWIFT_PRIVATE;
|
|
51
55
|
|
|
52
56
|
public:
|
|
53
57
|
PlayerState() = default;
|
|
54
|
-
explicit PlayerState(std::optional<std::variant<nitro::NullType, TrackItem>> currentTrack, double currentPosition, double totalDuration, TrackPlayerState currentState, std::optional<std::variant<nitro::NullType, std::string>> currentPlaylistId, double currentIndex): currentTrack(currentTrack), currentPosition(currentPosition), totalDuration(totalDuration), currentState(currentState), currentPlaylistId(currentPlaylistId), currentIndex(currentIndex) {}
|
|
58
|
+
explicit PlayerState(std::optional<std::variant<nitro::NullType, TrackItem>> currentTrack, double currentPosition, double totalDuration, TrackPlayerState currentState, std::optional<std::variant<nitro::NullType, std::string>> currentPlaylistId, double currentIndex, CurrentPlayingType currentPlayingType): currentTrack(currentTrack), currentPosition(currentPosition), totalDuration(totalDuration), currentState(currentState), currentPlaylistId(currentPlaylistId), currentIndex(currentIndex), currentPlayingType(currentPlayingType) {}
|
|
55
59
|
};
|
|
56
60
|
|
|
57
61
|
} // namespace margelo::nitro::nitroplayer
|
|
@@ -69,7 +73,8 @@ namespace margelo::nitro {
|
|
|
69
73
|
JSIConverter<double>::fromJSI(runtime, obj.getProperty(runtime, "totalDuration")),
|
|
70
74
|
JSIConverter<margelo::nitro::nitroplayer::TrackPlayerState>::fromJSI(runtime, obj.getProperty(runtime, "currentState")),
|
|
71
75
|
JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::fromJSI(runtime, obj.getProperty(runtime, "currentPlaylistId")),
|
|
72
|
-
JSIConverter<double>::fromJSI(runtime, obj.getProperty(runtime, "currentIndex"))
|
|
76
|
+
JSIConverter<double>::fromJSI(runtime, obj.getProperty(runtime, "currentIndex")),
|
|
77
|
+
JSIConverter<margelo::nitro::nitroplayer::CurrentPlayingType>::fromJSI(runtime, obj.getProperty(runtime, "currentPlayingType"))
|
|
73
78
|
);
|
|
74
79
|
}
|
|
75
80
|
static inline jsi::Value toJSI(jsi::Runtime& runtime, const margelo::nitro::nitroplayer::PlayerState& arg) {
|
|
@@ -80,6 +85,7 @@ namespace margelo::nitro {
|
|
|
80
85
|
obj.setProperty(runtime, "currentState", JSIConverter<margelo::nitro::nitroplayer::TrackPlayerState>::toJSI(runtime, arg.currentState));
|
|
81
86
|
obj.setProperty(runtime, "currentPlaylistId", JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::toJSI(runtime, arg.currentPlaylistId));
|
|
82
87
|
obj.setProperty(runtime, "currentIndex", JSIConverter<double>::toJSI(runtime, arg.currentIndex));
|
|
88
|
+
obj.setProperty(runtime, "currentPlayingType", JSIConverter<margelo::nitro::nitroplayer::CurrentPlayingType>::toJSI(runtime, arg.currentPlayingType));
|
|
83
89
|
return obj;
|
|
84
90
|
}
|
|
85
91
|
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
@@ -96,6 +102,7 @@ namespace margelo::nitro {
|
|
|
96
102
|
if (!JSIConverter<margelo::nitro::nitroplayer::TrackPlayerState>::canConvert(runtime, obj.getProperty(runtime, "currentState"))) return false;
|
|
97
103
|
if (!JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::canConvert(runtime, obj.getProperty(runtime, "currentPlaylistId"))) return false;
|
|
98
104
|
if (!JSIConverter<double>::canConvert(runtime, obj.getProperty(runtime, "currentIndex"))) return false;
|
|
105
|
+
if (!JSIConverter<margelo::nitro::nitroplayer::CurrentPlayingType>::canConvert(runtime, obj.getProperty(runtime, "currentPlayingType"))) return false;
|
|
99
106
|
return true;
|
|
100
107
|
}
|
|
101
108
|
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// PresetType.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/NitroHash.hpp>)
|
|
11
|
+
#include <NitroModules/NitroHash.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
#if __has_include(<NitroModules/JSIConverter.hpp>)
|
|
16
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
17
|
+
#else
|
|
18
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
19
|
+
#endif
|
|
20
|
+
#if __has_include(<NitroModules/NitroDefines.hpp>)
|
|
21
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
22
|
+
#else
|
|
23
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::nitroplayer {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An enum which can be represented as a JavaScript union (PresetType).
|
|
30
|
+
*/
|
|
31
|
+
enum class PresetType {
|
|
32
|
+
BUILT_IN SWIFT_NAME(builtIn) = 0,
|
|
33
|
+
CUSTOM SWIFT_NAME(custom) = 1,
|
|
34
|
+
} CLOSED_ENUM;
|
|
35
|
+
|
|
36
|
+
} // namespace margelo::nitro::nitroplayer
|
|
37
|
+
|
|
38
|
+
namespace margelo::nitro {
|
|
39
|
+
|
|
40
|
+
// C++ PresetType <> JS PresetType (union)
|
|
41
|
+
template <>
|
|
42
|
+
struct JSIConverter<margelo::nitro::nitroplayer::PresetType> final {
|
|
43
|
+
static inline margelo::nitro::nitroplayer::PresetType fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
44
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
45
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
46
|
+
case hashString("built-in"): return margelo::nitro::nitroplayer::PresetType::BUILT_IN;
|
|
47
|
+
case hashString("custom"): return margelo::nitro::nitroplayer::PresetType::CUSTOM;
|
|
48
|
+
default: [[unlikely]]
|
|
49
|
+
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum PresetType - invalid value!");
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::nitroplayer::PresetType arg) {
|
|
53
|
+
switch (arg) {
|
|
54
|
+
case margelo::nitro::nitroplayer::PresetType::BUILT_IN: return JSIConverter<std::string>::toJSI(runtime, "built-in");
|
|
55
|
+
case margelo::nitro::nitroplayer::PresetType::CUSTOM: return JSIConverter<std::string>::toJSI(runtime, "custom");
|
|
56
|
+
default: [[unlikely]]
|
|
57
|
+
throw std::invalid_argument("Cannot convert PresetType to JS - invalid value: "
|
|
58
|
+
+ std::to_string(static_cast<int>(arg)) + "!");
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
62
|
+
if (!value.isString()) {
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
66
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
67
|
+
case hashString("built-in"):
|
|
68
|
+
case hashString("custom"):
|
|
69
|
+
return true;
|
|
70
|
+
default:
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
} // namespace margelo::nitro
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// StorageLocation.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2026 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#if __has_include(<NitroModules/NitroHash.hpp>)
|
|
11
|
+
#include <NitroModules/NitroHash.hpp>
|
|
12
|
+
#else
|
|
13
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
14
|
+
#endif
|
|
15
|
+
#if __has_include(<NitroModules/JSIConverter.hpp>)
|
|
16
|
+
#include <NitroModules/JSIConverter.hpp>
|
|
17
|
+
#else
|
|
18
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
19
|
+
#endif
|
|
20
|
+
#if __has_include(<NitroModules/NitroDefines.hpp>)
|
|
21
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
22
|
+
#else
|
|
23
|
+
#error NitroModules cannot be found! Are you sure you installed NitroModules properly?
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::nitroplayer {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* An enum which can be represented as a JavaScript union (StorageLocation).
|
|
30
|
+
*/
|
|
31
|
+
enum class StorageLocation {
|
|
32
|
+
PRIVATE SWIFT_NAME(private) = 0,
|
|
33
|
+
PUBLIC SWIFT_NAME(public) = 1,
|
|
34
|
+
} CLOSED_ENUM;
|
|
35
|
+
|
|
36
|
+
} // namespace margelo::nitro::nitroplayer
|
|
37
|
+
|
|
38
|
+
namespace margelo::nitro {
|
|
39
|
+
|
|
40
|
+
// C++ StorageLocation <> JS StorageLocation (union)
|
|
41
|
+
template <>
|
|
42
|
+
struct JSIConverter<margelo::nitro::nitroplayer::StorageLocation> final {
|
|
43
|
+
static inline margelo::nitro::nitroplayer::StorageLocation fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
44
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
45
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
46
|
+
case hashString("private"): return margelo::nitro::nitroplayer::StorageLocation::PRIVATE;
|
|
47
|
+
case hashString("public"): return margelo::nitro::nitroplayer::StorageLocation::PUBLIC;
|
|
48
|
+
default: [[unlikely]]
|
|
49
|
+
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum StorageLocation - invalid value!");
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::nitroplayer::StorageLocation arg) {
|
|
53
|
+
switch (arg) {
|
|
54
|
+
case margelo::nitro::nitroplayer::StorageLocation::PRIVATE: return JSIConverter<std::string>::toJSI(runtime, "private");
|
|
55
|
+
case margelo::nitro::nitroplayer::StorageLocation::PUBLIC: return JSIConverter<std::string>::toJSI(runtime, "public");
|
|
56
|
+
default: [[unlikely]]
|
|
57
|
+
throw std::invalid_argument("Cannot convert StorageLocation to JS - invalid value: "
|
|
58
|
+
+ std::to_string(static_cast<int>(arg)) + "!");
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
62
|
+
if (!value.isString()) {
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
66
|
+
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
67
|
+
case hashString("private"):
|
|
68
|
+
case hashString("public"):
|
|
69
|
+
return true;
|
|
70
|
+
default:
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
} // namespace margelo::nitro
|
|
@@ -29,6 +29,7 @@
|
|
|
29
29
|
#include <NitroModules/Null.hpp>
|
|
30
30
|
#include <variant>
|
|
31
31
|
#include <optional>
|
|
32
|
+
#include <NitroModules/AnyMap.hpp>
|
|
32
33
|
|
|
33
34
|
namespace margelo::nitro::nitroplayer {
|
|
34
35
|
|
|
@@ -44,10 +45,11 @@ namespace margelo::nitro::nitroplayer {
|
|
|
44
45
|
double duration SWIFT_PRIVATE;
|
|
45
46
|
std::string url SWIFT_PRIVATE;
|
|
46
47
|
std::optional<std::variant<nitro::NullType, std::string>> artwork SWIFT_PRIVATE;
|
|
48
|
+
std::optional<std::shared_ptr<AnyMap>> extraPayload SWIFT_PRIVATE;
|
|
47
49
|
|
|
48
50
|
public:
|
|
49
51
|
TrackItem() = default;
|
|
50
|
-
explicit TrackItem(std::string id, std::string title, std::string artist, std::string album, double duration, std::string url, std::optional<std::variant<nitro::NullType, std::string>> artwork): id(id), title(title), artist(artist), album(album), duration(duration), url(url), artwork(artwork) {}
|
|
52
|
+
explicit TrackItem(std::string id, std::string title, std::string artist, std::string album, double duration, std::string url, std::optional<std::variant<nitro::NullType, std::string>> artwork, std::optional<std::shared_ptr<AnyMap>> extraPayload): id(id), title(title), artist(artist), album(album), duration(duration), url(url), artwork(artwork), extraPayload(extraPayload) {}
|
|
51
53
|
};
|
|
52
54
|
|
|
53
55
|
} // namespace margelo::nitro::nitroplayer
|
|
@@ -66,7 +68,8 @@ namespace margelo::nitro {
|
|
|
66
68
|
JSIConverter<std::string>::fromJSI(runtime, obj.getProperty(runtime, "album")),
|
|
67
69
|
JSIConverter<double>::fromJSI(runtime, obj.getProperty(runtime, "duration")),
|
|
68
70
|
JSIConverter<std::string>::fromJSI(runtime, obj.getProperty(runtime, "url")),
|
|
69
|
-
JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::fromJSI(runtime, obj.getProperty(runtime, "artwork"))
|
|
71
|
+
JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::fromJSI(runtime, obj.getProperty(runtime, "artwork")),
|
|
72
|
+
JSIConverter<std::optional<std::shared_ptr<AnyMap>>>::fromJSI(runtime, obj.getProperty(runtime, "extraPayload"))
|
|
70
73
|
);
|
|
71
74
|
}
|
|
72
75
|
static inline jsi::Value toJSI(jsi::Runtime& runtime, const margelo::nitro::nitroplayer::TrackItem& arg) {
|
|
@@ -78,6 +81,7 @@ namespace margelo::nitro {
|
|
|
78
81
|
obj.setProperty(runtime, "duration", JSIConverter<double>::toJSI(runtime, arg.duration));
|
|
79
82
|
obj.setProperty(runtime, "url", JSIConverter<std::string>::toJSI(runtime, arg.url));
|
|
80
83
|
obj.setProperty(runtime, "artwork", JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::toJSI(runtime, arg.artwork));
|
|
84
|
+
obj.setProperty(runtime, "extraPayload", JSIConverter<std::optional<std::shared_ptr<AnyMap>>>::toJSI(runtime, arg.extraPayload));
|
|
81
85
|
return obj;
|
|
82
86
|
}
|
|
83
87
|
static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
|
|
@@ -95,6 +99,7 @@ namespace margelo::nitro {
|
|
|
95
99
|
if (!JSIConverter<double>::canConvert(runtime, obj.getProperty(runtime, "duration"))) return false;
|
|
96
100
|
if (!JSIConverter<std::string>::canConvert(runtime, obj.getProperty(runtime, "url"))) return false;
|
|
97
101
|
if (!JSIConverter<std::optional<std::variant<nitro::NullType, std::string>>>::canConvert(runtime, obj.getProperty(runtime, "artwork"))) return false;
|
|
102
|
+
if (!JSIConverter<std::optional<std::shared_ptr<AnyMap>>>::canConvert(runtime, obj.getProperty(runtime, "extraPayload"))) return false;
|
|
98
103
|
return true;
|
|
99
104
|
}
|
|
100
105
|
};
|
|
@@ -29,8 +29,8 @@ namespace margelo::nitro::nitroplayer {
|
|
|
29
29
|
* An enum which can be represented as a JavaScript union (TrackPlayerState).
|
|
30
30
|
*/
|
|
31
31
|
enum class TrackPlayerState {
|
|
32
|
-
|
|
33
|
-
|
|
32
|
+
PAUSED SWIFT_NAME(paused) = 0,
|
|
33
|
+
PLAYING SWIFT_NAME(playing) = 1,
|
|
34
34
|
STOPPED SWIFT_NAME(stopped) = 2,
|
|
35
35
|
} CLOSED_ENUM;
|
|
36
36
|
|
|
@@ -44,8 +44,8 @@ namespace margelo::nitro {
|
|
|
44
44
|
static inline margelo::nitro::nitroplayer::TrackPlayerState fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
|
|
45
45
|
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
|
|
46
46
|
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
47
|
-
case hashString("playing"): return margelo::nitro::nitroplayer::TrackPlayerState::PLAYING;
|
|
48
47
|
case hashString("paused"): return margelo::nitro::nitroplayer::TrackPlayerState::PAUSED;
|
|
48
|
+
case hashString("playing"): return margelo::nitro::nitroplayer::TrackPlayerState::PLAYING;
|
|
49
49
|
case hashString("stopped"): return margelo::nitro::nitroplayer::TrackPlayerState::STOPPED;
|
|
50
50
|
default: [[unlikely]]
|
|
51
51
|
throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum TrackPlayerState - invalid value!");
|
|
@@ -53,8 +53,8 @@ namespace margelo::nitro {
|
|
|
53
53
|
}
|
|
54
54
|
static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::nitroplayer::TrackPlayerState arg) {
|
|
55
55
|
switch (arg) {
|
|
56
|
-
case margelo::nitro::nitroplayer::TrackPlayerState::PLAYING: return JSIConverter<std::string>::toJSI(runtime, "playing");
|
|
57
56
|
case margelo::nitro::nitroplayer::TrackPlayerState::PAUSED: return JSIConverter<std::string>::toJSI(runtime, "paused");
|
|
57
|
+
case margelo::nitro::nitroplayer::TrackPlayerState::PLAYING: return JSIConverter<std::string>::toJSI(runtime, "playing");
|
|
58
58
|
case margelo::nitro::nitroplayer::TrackPlayerState::STOPPED: return JSIConverter<std::string>::toJSI(runtime, "stopped");
|
|
59
59
|
default: [[unlikely]]
|
|
60
60
|
throw std::invalid_argument("Cannot convert TrackPlayerState to JS - invalid value: "
|
|
@@ -67,8 +67,8 @@ namespace margelo::nitro {
|
|
|
67
67
|
}
|
|
68
68
|
std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
|
|
69
69
|
switch (hashString(unionValue.c_str(), unionValue.size())) {
|
|
70
|
-
case hashString("playing"):
|
|
71
70
|
case hashString("paused"):
|
|
71
|
+
case hashString("playing"):
|
|
72
72
|
case hashString("stopped"):
|
|
73
73
|
return true;
|
|
74
74
|
default:
|