Music player with React and Node.js
Harmony is an open community of independent music lovers similar to Spotify, or Deezer. Harmony is a streaming music web application for personal use where users can listen their music and discover songs, playlists and artists.
This project was made by a team of passionate music developers using continuous integration and agile methodologies.
This app has been built with MERN stack and some complements like Auth0 to manage the users information.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
You need to install NodeJs and Install the NPM packages with npm install command. You will also be required to create accounts for: - MongoDB Atlas - Auth0
First, you will need to clone or fork the repository into your Github account:
frontend ->$ git clone https://github.com/martapunset/musicplayer-final-project backend -> $ git clone https://github.com/martapunset/music-player-final-project-backend
When you have all the dependencies installed you need to create two .env files, one located in client folder, one in server folder containing the new encryption keys. Please refer to the examples below:
Folder structure 🗂
├── Vite-project // Fronted Harmony │ ├── src │ │ ├── api │ │ ├── assets │ │ ├── auth │ │ ├── components │ │ ├── musicProvider │ │ ├── pages │ │ └── router │ │ └── ui │ │ └── utils │ │ └── App.jsx │ │ └── main.jsx
This front end side is the client views. Here we make request to back end, we can get user information or resources to show lastest updatest.
- Clean & efficient Code
- API architecture with the easiest flow for the frontend
- Comfortable user experience
- Safe server side
- Transparent and fluid team communication
- Collaborative work
In order to achieve all of our goals we have implemented the Scrum Agile Methodology. We divided all the process into four separated Sprints contained within 3 weeks, everyone of them with their own goals. To manage those sprints we set daily, sprint plannings and review and sprint retrospective meetings. We used Github Projects to divide our sprints, issues and tasks on boards using the Kanban structure. We also implemented a code review system in order to get all the team connected with all parts of the project.
Based on Agile methodologies we had daily reviews, sprint plannings and sprint reviews. This was done in order to agree on the requirements, design, develop, test, deploy and review each sprint.
- ReactJS
- React-hot-toast
- React-hook-form
- React-h5-audio-player
- React-icons
- Auth0
- Axios
- MaterialUI
- Framer-motion
- React-Router-Dom
- SASS
- Styled-components
Members of the Harmony group
Antonio Martín Galdeano |
Lokesh Pereiro |
Marta Punset |
Elisabet Ramos |
Pau Tomás Díez |