Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/akiayu13/music-player
https://github.com/akiayu13/music-player
react spotify tailwind zustand
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/akiayu13/music-player
- Owner: akiayu13
- Created: 2024-08-25T10:53:13.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-26T15:49:33.000Z (5 months ago)
- Last Synced: 2024-11-03T20:42:25.658Z (3 months ago)
- Topics: react, spotify, tailwind, zustand
- Language: JavaScript
- Homepage: https://music-player-akiayu13.vercel.app
- Size: 486 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# π΅ Music Player
## Overview
This is a simple and modern music player built with React.js. It uses Zustand for state management and Tailwind CSS for styling. The player is responsive, meaning it works well on both large and small screens. π§## Features
- **Responsive Design:** π± Adjusts to different screen sizes. On smaller screens, the player becomes the main interface with a menu to show the song list.
- **State Management:** π Zustand is used to keep track of the music playerβs state.
- **API Integration:** π Songs are loaded from a REST API.
- Song list API: `https://cms.samespace.com/items/songs`
- Cover images: `https://cms.samespace.com/assets/{COVER_IMAGE_ID}`
- **Continuous Playback:** πΆ Music keeps playing even if you switch tabs.
- **Dynamic Background:** π¨ The background color changes based on the album cover of the current song.
- **Smooth Interface:** π» The app includes animations for things like loading the song list and changing background colors.## Main Functions
- **Search:** π Find songs by name.
- **Music Controls:** π΅ Play, pause, skip to the next or previous song.
- **Tab Navigation:** π Switch between different views like "For You" and "Top Tracks".
- **Seeker:** β© Drag the bar to move to a different part of the song.## Live Demo
Check out the live version of the Music Player:
- **Vercel Demo:** [Music Player Demo](https://music-player-akiayu13.vercel.app/) π## Getting Started
### Requirements
Before starting, make sure you have:
- Node.js (version 14 or higher) π₯
- npm or yarn π¦### Installation
1. **Clone the project:**
```bash
git clone https://github.com/your-username/music-player.git
cd music-player
```
2. **Install the necessary packages:**
```bash
npm install
```
or
```bash
yarn install
```
3. **Run the development server:**
```bash
npm run dev
```
or
```bash
yarn dev
```
4. **Open your browser** and go to [http://localhost:3000](http://localhost:3000) to see the app in action.## API Details
The music player uses the following API:### Get Song List
```http
GET /items/songs
```This API returns a list of songs that are shown in the app.
### Get Cover Image
```http
GET /assets/{COVER_IMAGE_ID}
```This API fetches the cover image for the current song.
## Future Ideas
- **User Accounts:** π€ Allow users to log in and save their favorite songs.
- **Playlists:** πΌ Let users create and manage playlists.## Contributions
If you want to help improve this project, you can send a pull request or open an issue on GitHub. π