DEV Community

Cover image for So I created Spotify Clone in React(kinda)

So I created Spotify Clone in React(kinda)

Ferdo Vukojević on August 12, 2020

Hello Community! šŸ‘‹ Before I dive into the app, just wanted to give a few pointers, so nobody get's confused. This app is only created ...
Collapse
 
bryanelalami profile image
bryanelalami • Edited

Thank you Ferdo for your work, I'm super pumped to get this project done. But actually, I'm facing an issue. After so many researches, I'm stucked. I'm trying to add the play music functionality .

Error React JS

Collapse
 
fvukojevic profile image
Ferdo Vukojević

The play music functionality should already be implemented. If you can see your playlists, just click on the song so it is shown in the footer and then the play button should work.

2 potential issues could be that a specific track doesnt have a previrew url
Or that you didnt set up your spotify clientId and redirectUrl

Can you confirm that both of those things are set up correctly and that your playlist is pulled after login?

Collapse
 
bryanelalami profile image
bryanelalami

Spotify clientID and redirectUri are set up. The problems comes from

import React from "react";
import "./Body.css";
import Header from "./Header";
import { useDataLayerValue } from "./DataLayer";
import PlayCircleFilledIcon from "@material-ui/icons/PlayCircleFilled";
import PauseCircleFilledIcon from "@material-ui/icons/PauseCircleFilled";
import FavoriteIcon from "@material-ui/icons/Favorite";
import MoreHorizIcon from "@material-ui/icons/MoreHoriz";
import SongRow from "./SongRow";
import {useSoundLayerValue} from "./SoundLayer";

function Body({ spotify }) {
  const [{current_playlist, tracks, track}] = useDataLayerValue();
  const [{playing, volume}, soundDispatch] = useSoundLayerValue();

  const startPlaying = () => {
    soundDispatch({
      type: "SET_PLAYING",
      playing: true,
    });
    soundDispatch({
      type: "SET_VOLUME",
      volume: volume / 100,
    });
  };
  const stopPlaying = () => {
    soundDispatch({
      type: "SET_PLAYING",
      playing: false,
    });
  };
  return (
    
      
      
        
        
          PLAYLIST
          

Discover Weekly

{current_playlist?.description}

{playing ? : } {tracks?.items.map(track => { return ; })} ); } export default Body;
Thread Thread
 
bryanelalami profile image
bryanelalami

Everything is working fine right now !

Thread Thread
 
fvukojevic profile image
Ferdo Vukojević

I love to hear. The functionalities are just getting started. Right now play button, volume and repeat should work (volume has a bit of a bug on it). I will try to add functionality to shuffle/prev/next buttons today

Thread Thread
 
bryanelalami profile image
bryanelalami

We can do together if you want to ! What is the bug about he volume button ? What's the logic behind shuffle/prev/next buttons ?

Thread Thread
 
fvukojevic profile image
Ferdo Vukojević

The volume button doesn't seem to transfer it's state when you change the song while the one is playing. It will reset again to the starting position.

Yea getting the help from the community would be lovely because as I said, I am very much a newbie to React (would be a lot more comfortable in Vue.js)

So the functionality of buttons is quite simple really

  • Shuffle -> When the song ends, random one from playlist starts
  • Next -> Starts the next from the playlist (basically find the current one by id, and go next)
  • Prev -> Does the opposite, and starts the one previous in the playlist

After those footer functionalities I will start working on the Home & Search buttons. I might refactor the design prior to that šŸ˜

Thread Thread
 
bryanelalami profile image
bryanelalami

Would be great to collaborate and help each other !

I'm new as well in React Dev so that's I sound like a newbie.

Can you help me out with this ?

alt text for accessibility

Thread Thread
 
bryanelalami profile image
bryanelalami

There is also another problem that I'm facing... const redirectUri seems to be incorrect. When deploying the website with firebase , when logged in, it redirects me to localhost:3000 and because the server is down, it keeps me redirecting to the wrong URL

Thread Thread
 
fvukojevic profile image
Ferdo Vukojević

I would suggest you use your own clientId. It is very simple to get at developer.spotify.com/dashboard
RedirectUri gets pulled from window.location.origin so it should work as long as you setup inside your dashboard the same uri your app is hosted on.

So steps would be:
Go to spotify dashboard for developers, create an app, take the clientId and place it inside spotify.js file.
And then inside the spotify dashboard in edit settings, set the redirect url to match the url your app is hosted.

Thread Thread
 
bryanelalami profile image
bryanelalami

It would be great to jump on a call , are you available ?

Collapse
 
killianfrappartdev profile image
Killian Frappart

Well done! That is a great project šŸ˜

Unfortunately I was not able to log in, I tried to connect using my Facebook account but it would not let me log in for some reasons...

I don't know if someone experienced the same or if I am the only one.

Collapse
 
fvukojevic profile image
Ferdo Vukojević

If you have time you can try following instructions and try to set it up locally. Maybe the clientId is directly connected to users account and thats why it always works for me

Collapse
 
bento profile image
Bento

Nice project ! Did you deploy it on Heroku for example ? This way we could test it, i'tll be more fun for us than just to see screenshots of the app ;)

Collapse
 
gopigaurav profile image
gopi

hey fredo i am encountering an issue after deployment

Collapse
 
dm3xx profile image
dm3xx
Collapse
 
yashshah224 profile image
Yash Shah • Edited

I just want to ask why we can't play whole song? Why only 30 seconds?
What if i want to play the whole song?

Collapse
 
fvukojevic profile image
Ferdo Vukojević

Spotify api doesn't give you the full song. Makes sense, otherwise you could make your own up, upon their api

Collapse
 
dm3xx profile image
dm3xx
Collapse
 
renanosilva profile image
Renan Oliveira

Kudos for Hybrid Theory. You know what's good :)

Collapse
 
lethanhvietctt5 profile image
Le Thanh Viet

Here is my clone Spotify by using ReactJS, NextJS
Github: github.com/lethanhvietctt5/react-s...
I hope it will help everyone who is learning react and want to clone Spotify

Collapse
 
sumitmalviyaau8 profile image
Sumit Malviya

How can I get access token to fetch data from another API of Spotify itself..like the album , latest songs etc?