Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
react-native-spotify
Advanced tools
A native module that allows you to use the Spotify SDK API (IOS) with JavaScript through react-native.
##Intro
A native module that allows you to use the Spotify SDK API (IOS beta 17) with JavaScript through react-native.
##Set-up: ###Using npm
Recomended
Use npm install react-native-spotify
from the directory of your project in your command line.
Download the Spotify IOS SDK beta 17 here and unzip it.
Open your react native project in Xcode and drag the unzipped Spotify.framework
file into the Frameworks
group in your Xcode project (create the group if it doesn’t already exist). In the import dialog, tick the box for Copy items into destinations group folder (or Destination: Copy items if needed).
Please folow the instructions on the "Creating Your Client ID, Secret and Callback URI" and "Setting Up Your Build Environment" sections of the Spotify iOS SDK Tutorial
Important Note! When adding frameworks to the list in the "Link Binary With Libraries" section you wll need to add
WebKit.framework
in addition to those mentioned in the tutorial.
node-modules/react-native-spotify/
and copy the following files to the ios
directory of your project:
SpotifyLoginViewController.m
SpotifyLoginViewController.h
SpotifyAuth.m
SpotifyAuth.h
###Using git
Fork and clone the repo.
Download the Spotify IOS SDK beta 17 here and unzip it.
Open your react native project in Xcode and drag the unzipped Spotify.framework
file into the Frameworks
group in your Xcode project (create the group if it doesn’t already exist). In the import dialog, tick the box for Copy items into destinations group folder (or Destination: Copy items if needed).
Please folow the instructions on the "Creating Your Client ID, Secret and Callback URI" and "Setting Up Your Build Environment" sections of the Spotify iOS SDK Tutorial
Important Note! When adding frameworks to the list in the "Link Binary With Libraries" section you wll need to add
WebKit.framework
in addition to those mentioned in the tutorial.
react-native-spotify/spotifyModule/ios
and copy the following files to the ios
directory of your project:
SpotifyLoginViewController.m
SpotifyLoginViewController.h
SpotifyAuth.m
SpotifyAuth.h
##How to use:
//You need to import NativeModules to your view
import { NativeModules } from 'react-native';
//Assign our module from NativeModules and assign it to a variable
var SpotifyAuth = NativeModules.SpotifyAuth;
class yourComponent extends Component {
//Some code ...
someMethod(){
//You need this to Auth a user, without it you cant use any method!
SpotifyAuth.setClientID('Your ClientId','Your redirectURL', ['streaming'], (error)=>{
if(error){
//handle error
} else {
//handle success
}
});
}
}
##Exposed API:
###Auth:
setClientID:setRedirectURL:setRequestedScopes:callback
You need this to Auth a user, without it you cant use any other methods!
Set your Client ID, Redirect URL, Scopes and start the auth process
Parameter | description |
---|---|
Client ID | (String) The client ID of your registered Spotify app |
Redirect URL | (String) The Redirect URL of your registered Spotify app |
Scopes | (Array) list of scopes of your app, see here |
Callback | (Function) a callback to handle the login success/error |
Example:
SpotifyAuth.setClientID('your-clientID','your-redirectURL',['streaming',...],(error)=>{console.log(error)});
###SPTAudioStreamingController Class:
initialized
Returns true when SPTAudioStreamingController is initialized, otherwise false
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.initialized((res)=>{console.log(res);});
Returns true if the receiver is logged into the Spotify service, otherwise false
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.loggedIn((res)=>{console.log(res);});
Returns true if the receiver is playing audio, otherwise false
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.isPlaying((res)=>{console.log(res);});
Returns the volume
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.volume((res)=>{console.log(res);});
Returns true if the receiver expects shuffled playback, otherwise false
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.shuffle((res)=>{console.log(res);});
Returns true if the receiver expects repeated playback, otherwise false
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.repeat((res)=>{console.log(res);});
Returns the current approximate playback position of the current track
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.currentPlaybackPosition((res)=>{console.log(res);});
Returns the length of the current track
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.currentTrackDuration((res)=>{console.log(res);});
Returns the current track URI, playing or not
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.currentTrackURI((res)=>{console.log(res);});
Returns the currenly playing track index
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.currentTrackIndex((res)=>{console.log(res);});
Returns the current streaming bitrate the receiver is using
Parameter | description |
---|---|
Callback | (Function) a callback to handle the response |
Example:
SpotifyModule.targetBitrate((res)=>{console.log(res);});
Logout from Spotify
Parameter | description |
---|---|
N/A | N/A |
Example:
SpotifyModule.logout();
Set playback volume to the given level. Volume is a value between 0.0
and 1.0
.
Parameter | description |
---|---|
volume | (Number) The volume to change to, value between 0.0 and 1.0 |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.setVolume(0.8,(error)=>{console.log(error);});
Set the target streaming bitrate. 0
for low, 1
for normal and 2
for high
Parameter | description |
---|---|
bitrate | (Number) The bitrate to target |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.setTargetBitrate(2,(error)=>{console.log(error);});
Seek playback to a given location in the current track (in secconds).
Parameter | description |
---|---|
offset | (Number) The time to seek to |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.seekToOffset(110,(error)=>{console.log(error);});
-playURIs:withOptions:callback:
Play a list of Spotify URIs.(at most 100 tracks).SPTPlayOptions
containing extra information about the play request such as which track to play and from which starting position within the track.
Parameter | description |
---|---|
uris | (Array) The array of URI’s to play (at most 100 tracks) |
options | (Object) with trackIndex:(Number) and/or startTime:(Number) (can be null) |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.playURIs(["spotify:track:6HxIUB3fLRS8W3LfYPE8tP",...], {trackIndex :0, startTime:12.0},(error)=>{console.log(error)});
-replaceURIs:withCurrentTrack:callback:
Replace the current list of tracks without stopping playback.
Parameter | description |
---|---|
uris | (Array) The array of URI’s to play |
index | (Number) The current track in the list |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.replaceURIs(["spotify:track:6HxIUB3fLRS8W3LfYPE8tP",...], 0, (error)=>{console.log(error)});
Play a Spotify URI.
Parameter | description |
---|---|
uri | (Number) The URI to play |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.playURI("spotify:track:6HxIUB3fLRS8W3LfYPE8tP",(error)=>{console.log(error);});
Queue a Spotify URI.
Parameter | description |
---|---|
uri | (String) The URI to queue |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.queueURI("spotify:track:6HxIUB3fLRS8W3LfYPE8tP",(error)=>{console.log(error);});
Set the "playing" status of the receiver.
Parameter | description |
---|---|
playing | (Boolean) Pass true to resume playback, or false to pause it |
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.setIsPlaying(true,(error)=>{console.log(error);});
Stop playback and clear the queue and list of tracks.
Parameter | description |
---|---|
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.stop((error)=>{console.log(error);});
Go to the next track in the queue
Parameter | description |
---|---|
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.skipNext((error)=>{console.log(error);});
-skipPrevious:(RCTResponseSenderBlock)block
Go to the previous track in the queue
Parameter | description |
---|---|
Callback | (Function) a callback that will pass back an NSError object if an error ocurred |
Example:
SpotifyModule.skipPrevious((error)=>{console.log(error);});
###SPTSearch Class:
+performSearchWithQuery:queryType:offset:accessToken:market:callback:
Go to the previous track in the queue You need to have a session first
Parameter | description |
---|---|
searchQuery | (String) The query to pass to the search |
searchQueryType | (String) The type of search to do ('track', 'artist', 'album' or 'playList') |
offset | (Number) The index at which to start returning results |
market | (String) Either a ISO 3166-1 country code to filter the results to, or “from_token” |
Callback | (Function) callback to be called when the operation is complete. The block will pass an Array filled with json Objects on success, otherwise an error. |
Example:
SpotifyModule.performSearchWithQuery('lacri','artist',0,'US',(err, res)=>{
console.log('error', err);
console.log('result', res);
});
##Demo:
Included in the repo.
FAQs
A native module that allows you to use the Spotify SDK API (IOS) with JavaScript through react-native.
We found that react-native-spotify demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.