Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sourabh250/entertainment-app
Discover and manage your favorite movies and TV series easily. This app helps you explore, track, and enjoy a wide range of entertainment content, all in one place.
https://github.com/sourabh250/entertainment-app
axios bcrypt express framer-motion jwt mongodb moongose nodejs react redux-toolkit swiper
Last synced: 29 days ago
JSON representation
Discover and manage your favorite movies and TV series easily. This app helps you explore, track, and enjoy a wide range of entertainment content, all in one place.
- Host: GitHub
- URL: https://github.com/sourabh250/entertainment-app
- Owner: Sourabh250
- License: mit
- Created: 2024-09-04T17:44:52.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-09-18T16:06:50.000Z (5 months ago)
- Last Synced: 2025-01-22T06:12:52.432Z (29 days ago)
- Topics: axios, bcrypt, express, framer-motion, jwt, mongodb, moongose, nodejs, react, redux-toolkit, swiper
- Language: JavaScript
- Homepage: https://entertainment-app-frontend-18em.onrender.com/
- Size: 254 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Entertainment App
Welcome to the Entertainment App! This app is designed to provide you with a seamless entertainment experience. Whether you're looking for movies or TV shows, this app has got you covered.
## Features
- Browse a vast library of movies, TV shows
- Search for your favorite entertainment content
- Create personalized bookmarks
- Discover trending and recommended content
- Enjoy a smooth user interface## Table of Contents
- [Features](#features)
- [Technologies/Languages Used](#technologieslanguages-used)
- [Installation](#installation)
- [Usage](#usage)
- [Setup](#setup)
- [API Endpoints](#api-endpoints)
- [Deployment](#deployment)
- [Live API Documentation](#live-api-documentation)
- [Contributing](#contributing)
- [Author](#author)
- [License](#license)## Technologies/Languages Used
| data:image/s3,"s3://crabby-images/60485/60485025634a5e7a007c7aef54228a0d677cc446" alt="Node.js Logo" | data:image/s3,"s3://crabby-images/0d9ca/0d9caeeab3bbb33aae5df960ea7ed97c09e99a18" alt="Express" | data:image/s3,"s3://crabby-images/0ffcc/0ffcc929395ecc918cb1eb7ce4606d3bdced3477" alt="MongoDB" | data:image/s3,"s3://crabby-images/f214e/f214e9281c8543bdca16def6f0874c962e9e5e34" alt="React" | data:image/s3,"s3://crabby-images/956f5/956f5ad9f8285343e5cd4b1931fe0c67d8b3f57e" alt="Axios" |
|:--:|:--:|:--:|:--:|:--:|
| data:image/s3,"s3://crabby-images/1fc55/1fc55b7603dd56fe548130ad0bc81c62a2bd8750" alt="Redux" | data:image/s3,"s3://crabby-images/b2c76/b2c761964ca287932bee0b5ee0fcc84f02083a32" alt="Framer Motion" | data:image/s3,"s3://crabby-images/88558/885584c86477a8a1c999264d342f201165c713a1" alt="Swiper" | data:image/s3,"s3://crabby-images/a2754/a27542a6d4a064459ad7b1e0cae818b99462ea6d" alt="JWT" | data:image/s3,"s3://crabby-images/cb927/cb9270b31fdcb77ee95dc5c90153cb0f081f5f77" alt="Bcrypt" |- **Node.js** - JavaScript runtime used for building the server-side application.
- **Express** - Web application framework for Node.js, used to build the API.
- **MongoDB** - NoSQL database used for storing data.
- **Mongoose** - MongoDB object modeling tool for Node.js.
- **React** - Front-end JavaScript library for building user interfaces.
- **Axios** - Promise-based HTTP client used to make API requests.
- **Redux** - State management library for JavaScript apps, commonly used with React.
- **Framer Motion** - Library for animations in React applications.
- **Swiper** - Modern mobile touch slider with amazing transitions.
- **JSONWebToken (JWT)** - A compact, URL-safe means of representing claims to be transferred between two parties.
- **Bcrypt** - Library for hashing passwords to ensure secure user authentication.## Installation
1. Clone this repository to your local machine.
2. Navigate to the appropriate project directory.
3. Install the necessary dependencies by running `npm install`.
4. Start the app by running `npm start`.## Usage
1. Launch the app.
2. Browse through the available categories or use the search feature to find specific content.
3. Click on a movie, TV series to view more details.
4. Add items to your bookmark by clicking the bookmark icon.## Setup
To deploy the Entertainment App, you will need to set up both the frontend and backend separately.
#### Frontend
1. Clone the repository to your local machine:
```
git clone https://github.com/Sourabh250/entertainment-app.git
```2. Navigate to the frontend directory:
```
cd frontend
```3. Install the necessary dependencies by running:
```
npm install
```
4. Create a `.env` file at the root and add the following:
To run this project, you will need to add the following environment variable to your .env file
`REACT_APP_API_URL`.
You can use the provided .env.example file as a reference.
REACT_APP_API_URL = your_backend_api_url5. Start the frontend server:
```
npm start
```6. The frontend will be accessible at `http://localhost:3000`.
#### Backend
1. Navigate to the backend directory:
```
cd backend
```2. Install the necessary dependencies by running:
```
npm install
```
3. Create a .env file at the root and add the following:You will need to add the following environment variables to your .env file.
You can use the provided .env.example file as a reference.PORT = 8000
DATABASE_URL = your_database_connection_string
TMDB_API_KEY = your_tmdb_api_key
JWT_SECRET = your_jwt_secret_key
REFRESH_SECRET = your_refresh_secret_key
NODE_ENV = development/production
CORS_ORIGIN = your_frontend_url
DOMAIN_NAME = your_frontend_domain_name4. Start the backend server:
```
npm start
```5. The backend will be accessible at `http://localhost:8000`.
## API Endpoints
Here are some API endpoints. For a full list of API endpoints, check out the [Postman Documentation](https://www.postman.com/sourabhbanik234/workspace/test-workspace/collection/38358652-199eef21-5fc3-4561-8c88-a902fed16933?action=share&creator=38358652).
Get all movies
```
GET /api/movies
```
| Parameter | Type | Description |
| :-------- | :------- | :------------------------- |
| `None` | `None` | Retrieves a list of movies. |Search Movies
```
GET /api/movies/search/:query
```
| Parameter | Type | Description |
| :-------- | :------- | :------------------------- |
| `query` | `string` | **Required**. Search for movies based on query. |Get detailed info about a movie by ID
```
GET /api/movies/details/:id
```
| Parameter | Type | Description |
| :-------- | :------- | :------------------------- |
| `id` | `int` | **Required**. Get detailed info about a movie. |## Deployment
For deployment, follow these steps:#### 1. Prepare your environment:
Ensure that environment variables are set and the database is accessible.
#### 2. Deploy to your preferred hosting service:
For example, you can use platforms like Heroku, AWS, or Render.
#### 3. Set up deployment scripts if necessary:
Configure deployment settings according to your hosting provider's guidelines.[**Render Frontend Link**](https://entertainment-app-frontend-18em.onrender.com)
[**Render Backend Link**](https://entertainment-app-9u0i.onrender.com)
## Live API Documentation
Explore the API documentation and interact with the endpoints via Postman:
- **Production**: [Explore the API documentation](https://www.postman.com/sourabhbanik234/workspace/test-workspace/collection/38358652-199eef21-5fc3-4561-8c88-a902fed16933?action=share&creator=38358652)## Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.## Author
- [@Sourabh](https://github.com/Sourabh250) - Developer and maintainer of this project.
## License
This project is licensed under the MIT License - see the LICENSE file for details.[data:image/s3,"s3://crabby-images/8fe25/8fe252f76dc2a000f81c31eb23c03acd6799638b" alt="MIT License"](https://choosealicense.com/licenses/mit/)