Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/josuapsianturi/velflix
Velflix is a Laravel Netflix clone project using the TALL stack
https://github.com/josuapsianturi/velflix
alpinejs laravel laravel-9 laravel-netflix-clone laravel-project livewire netflix-clone tailwind tailwindcss tall-stack
Last synced: 4 days ago
JSON representation
Velflix is a Laravel Netflix clone project using the TALL stack
- Host: GitHub
- URL: https://github.com/josuapsianturi/velflix
- Owner: josuapsianturi
- License: mit
- Created: 2021-04-06T13:55:41.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-03-25T14:50:02.000Z (9 months ago)
- Last Synced: 2024-12-09T13:12:51.205Z (13 days ago)
- Topics: alpinejs, laravel, laravel-9, laravel-netflix-clone, laravel-project, livewire, netflix-clone, tailwind, tailwindcss, tall-stack
- Language: PHP
- Homepage:
- Size: 23.1 MB
- Stars: 116
- Watchers: 4
- Forks: 57
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
## About
Velflix is a Laravel [Netflix](https://netflix.com) clone project using TALL stack ([Tailwindcss](https://tailwindcss.com/), [Alpinejs](https://github.com/alpinejs/alpine/), [Laravel](https://laravel.com/), [Livewire](https://laravel-livewire.com/) ).
> **Note**
> Work in Progress## Table of Contents
* [Screenshots](#screenshots)
* [Requirements](#requirements)
* [Installation](#installation)
* [Testing](#testing)
* [Contributing](#contributing)
* [License](#license)![home page](https://raw.githubusercontent.com/josuapsianturi/velflix/main/public/img/home.png)
see full page [here](https://raw.githubusercontent.com/josuapsianturi/velflix/main/public/img/home-full-page.png)
![movies header](https://raw.githubusercontent.com/josuapsianturi/velflix/main/public/img/movies-header.png)
![movies](https://raw.githubusercontent.com/josuapsianturi/velflix/main/public/img/movies.png)
see full page [here](https://raw.githubusercontent.com/josuapsianturi/velflix/main/public/img/movies-full-page.png)
![Detail movies](https://raw.githubusercontent.com/josuapsianturi/velflix/main/public/img/details-movie.png)
Package | Version
--- | ---
[Node](https://nodejs.org/en/) | V14.19.1+
[Npm](https://nodejs.org/en/) | V6.14.16+
[Composer](https://getcomposer.org/) | V2.2.6+
[Php](https://www.php.net/) | V8.0.17+
[Mysql](https://www.mysql.com/) |V 8.0.27+> **Warning**
> Make sure to follow the requirements first.Here is how you can run the project locally:
1. Clone this repo
```sh
git clone https://github.com/josuapsianturi/velflix.git
```1. Go into the project root directory
```sh
cd velflix
```1. Copy .env.example file to .env file
```sh
cp .env.example .env
```
1. Create database `velflix` (you can change database name)1. Create account and get an API key themoviedb [ here](https://www.themoviedb.org/settings/api). Make sure to copy `API Read Access Token (v4 auth)`.
1. Go to `.env` file
- set database credentials (`DB_DATABASE=velflix`, `DB_USERNAME=root`, `DB_PASSWORD=`)
- paste `TMDB_TOKEN=(your API key)`
> Make sure to follow your database username and password1. Install PHP dependencies
```sh
composer install
```1. Generate key
```sh
php artisan key:generate
```1. install front-end dependencies
```sh
npm install && npm run build
```1. Run migration
```
php artisan migrate
```
1. Run seeder
```
php artisan db:seed
```
this command will create 2 users (admin and normal user):
> email: [email protected] , password: password> email: [email protected] , password: password
1. Run server
> for valet users visit `velflix.test` in your favorite browser
```sh
php artisan serve
```1. Visit `localhost:8000` in your favorite browser.
> Make sure to follow your Laravel local Development Environment.
1. Newsletter feature configuration (optional)
- Go to [mailchimp](https://mailchimp.com)
- Register your account, get API key and paste it into `.env` file. If you need help, you can follow these steps:
- Click Sign Up Free
- Enter your data, check your email and verify
- select Free, Next
- Do you have a list of contacts? (NO)
- Do you sell products or services online? (Neither, Products)
- continue
- Go to Profile > Extras > API keys
- Create a key and copy API key
- open the velflix project, go to `.env` file and paste it into `MAILCHIMP_KEY=paste API key here`
- Go to web.php and paste this code at the bottom or you can follow the documentation [here](https://mailchimp.com/developer/marketing/api/lists/get-lists-info/)
```php
Route::get('ping', function() {
$mailchimp = new MailchimpMarketing\ApiClient();
$mailchimp->setConfig([
'apiKey' => config('services.mailchimp.key'),
'server' => 'us5',
]);$response = $mailchimp->lists->getAllLists();
ddd($response);
});
```> make sure you fill in the `server` correctly, check the link at the top of your admin Mailchimp, for me its `https://us5.admin.mailchimp.com/account/api/` so i give the value of server is `us5`. if you get us6, change the server value to be `us6`.
- visit `localhost:8000/ping` or `velflix.test/ping` and copy value of id in the ` "lists" > 0 > "id"`
- open project, in .env file paste the id into `MAILCHIMP_LIST_SUBSCRIBERS=paste id here` and we ready to go
- visit `localhost:8000` or `velflix.test` test email for subscribing , and refresh your admin mailchimp it should be Your audience has increased 1 contact.14. Setup Laravel Socialite login with Google account (optional)
- Go to the [Google Developers Console](https://console.cloud.google.com/apis) get "GOOGLE_CLIENT_ID" and "GOOGLE_CLIENT_SECRET". paste it into `.env` file.
if you need help, you can follow these steps:
- Click Credentials menu, click "select a project" at the navbar > ALL > No organization > new project.
- project name 'velflix', location should be no organization > Create.
- Go to OAuth consent screen menu > Select External and Create
- App Information > app name 'velflix' choose user support email, fill email in developer contact information, save and continue
- Go to Credentials menu > click `+Create Credentials` at the top > select "OAuth Client ID" > select Application type "Web Application" > Name 'velflix'
- At the Authorized redirect URIs > +ADD URI > paste this into it `http://127.0.0.1:8000/login/google/callback` > Create.> NOTE: you can change the port to be `8080` or others, but make sure when you run `php artisan serve`, your project run in the same port.
- Copy `Your Client ID` and `Your Client Secret`
- Open velflix project, go to `.env` file and paste it in `GOOGLE_CLIENT_ID=paste_here` and `GOOGLE_CLIENT_SECRET=paste_here` and we ready to go
```sh
php artisan serve
```
- let's test, visit the project in your browser > Login > Login Google > choose account > and if success, it should be redirect to the movies page.
> Let me know if you get in trouble.### Pest
1. To run PHP testing for Laravel
> **Warning**
> Every time you run testing, you should run `php artisan db:seed` first```sh
vendor/bin/pest
```### Cypress
2. To run E2E testing
```sh
npx cypress run
```### Laravel Pint
3. To run coding style checks
```sh
vendor/bin/pint
```
### Laravel Psalm4. To run static analysis with Psalm
```sh
vendor/bin/psalm
```
### Larastan5. To run static analysis with PHPStan
```sh
vendor/bin/phpstan analyse
```Please see [CONTRIBUTING](CONTRIBUTING.md) for details.
## License
Velflix is an open-sourced software licensed under [the MIT license](https://github.com/josuapsianturi/velflix/blob/main/LICENSE)