Download Laravel App
composer create-project --prefer-dist laravel/laravel my-app
C:\xampp\htdocs\laravel>composer create-project --prefer-dist laravel/laravel my-app
Connecting our Database
open .env file root directory.
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laraveldb
DB_USERNAME=root
DB_PASSWORD=
Create Controller
php artisan make:controller ProductsController
C:\xampp\htdocs\laravel\my-app>php artisan make:controller ProductsController
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | //app/Http/Controllers/ProductsController.php <?php namespace App\Http\Controllers; use Illuminate\Http\Request; use App\Models\Product; class ProductsController extends Controller { public function index() { $products = Product::all(); return view( 'products' , compact( 'products' )); } public function cart() { return view( 'cart' ); } public function addToCart( $id ) { $product = Product::findOrFail( $id ); $cart = session()->get( 'cart' , []); if (isset( $cart [ $id ])) { $cart [ $id ][ 'quantity' ]++; } else { $cart [ $id ] = [ "product_name" => $product ->product_name, "photo" => $product ->photo, "price" => $product ->price, "quantity" => 1 ]; } session()->put( 'cart' , $cart ); return redirect()->back()->with( 'success' , 'Product add to cart successfully!' ); } public function update(Request $request ) { if ( $request ->id && $request ->quantity){ $cart = session()->get( 'cart' ); $cart [ $request ->id][ "quantity" ] = $request ->quantity; session()->put( 'cart' , $cart ); session()->flash( 'success' , 'Cart successfully updated!' ); } } public function remove(Request $request ) { if ( $request ->id) { $cart = session()->get( 'cart' ); if (isset( $cart [ $request ->id])) { unset( $cart [ $request ->id]); session()->put( 'cart' , $cart ); } session()->flash( 'success' , 'Product successfully removed!' ); } } } |
php artisan make:model Product -m
C:\xampp\htdocs\laravel\my-app>php artisan make:model Product -m
database/migrations/create_products_table.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | //database/migrations/create_products_table.php <?php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; return new class extends Migration { public function up() { Schema::create( 'products' , function (Blueprint $table ) { $table ->id(); $table ->string( 'product_name' ); $table ->text( 'product_description' ); $table ->string( 'photo' ); $table ->decimal( "price" , 6, 2); $table ->timestamps(); }); } public function down() { Schema::dropIfExists( 'products' ); } }; |
C:\xampp\htdocs\laravel\my-app>php artisan migrate
Model
app/Models/Product.php
1 2 3 4 5 6 7 8 9 10 11 12 13 | //app/Models/Product.php <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Product extends Model { use HasFactory; protected $fillable = [ 'product_name' , 'photo' , 'price' , 'product_description' ]; } |
Bootstrap 4
https://getbootstrap.com/docs/4.5/getting-started/introduction/
https://cdn.jsdelivr.net/npm/bootstrap@4.5.3/dist/css/bootstrap.min.css
Jquery
https://jquery.com/download/
CDN : jsDelivr CDN
https://www.jsdelivr.com/package/npm/jquery
https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 | //resources/views/layout.blade.php <!DOCTYPE html> <html> <head> <title>Laravel 9 Shopping Cart add to cart</title> <link rel= "stylesheet" href= "https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" > <link rel= "stylesheet" href= "https://cdn.jsdelivr.net/npm/bootstrap@4.5.3/dist/css/bootstrap.min.css" > <script src= "https://cdn.jsdelivr.net/npm/bootstrap@4.5.3/dist/js/bootstrap.bundle.min.js" ></script> <link href= "{{ asset('css/styles.css') }}" rel= "stylesheet" > </head> <body> <div class = "container" > <div class = "row" > <div class = "col-lg-12 col-sm-12 col-12" > <div class = "dropdown" > <button type= "button" class = "btn btn-primary" data-toggle= "dropdown" > <i class = "fa fa-shopping-cart" aria-hidden= "true" ></i> Cart <span class = "badge badge-pill badge-danger" >{{ count (( array ) session( 'cart' )) }}</span> </button> <div class = "dropdown-menu" > <div class = "row total-header-section" > @php $total = 0 @endphp @ foreach (( array ) session( 'cart' ) as $id => $details ) @php $total += $details [ 'price' ] * $details [ 'quantity' ] @endphp @ endforeach <div class = "col-lg-12 col-sm-12 col-12 total-section text-right" > <p>Total: <span class = "text-info" >$ {{ $total }}</span></p> </div> </div> @ if (session( 'cart' )) @ foreach (session( 'cart' ) as $id => $details ) <div class = "row cart-detail" > <div class = "col-lg-4 col-sm-4 col-4 cart-detail-img" > <img src= "{{ asset('img') }}/{{ $details['photo'] }}" /> </div> <div class = "col-lg-8 col-sm-8 col-8 cart-detail-product" > <p>{{ $details [ 'product_name' ] }}</p> <span class = "price text-info" > ${{ $details [ 'price' ] }}</span> <span class = "count" > Quantity:{{ $details [ 'quantity' ] }}</span> </div> </div> @ endforeach @ endif <div class = "row" > <div class = "col-lg-12 col-sm-12 col-12 text-center checkout" > <a href= "{{ route('cart') }}" class = "btn btn-primary btn-block" >View all</a> </div> </div> </div> </div> </div> </div> </div> <br/> <div class = "container" > @ if (session( 'success' )) <div class = "alert alert-success" > {{ session( 'success' ) }} </div> @ endif @yield( 'content' ) </div> @yield( 'scripts' ) </body> </html> |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | //resources/views/products.blade.php @ extends ( 'layout' ) @section( 'content' ) <div class = "row" > @ foreach ( $products as $product ) <div class = "col-xs-18 col-sm-6 col-md-4" style= "margin-top:10px;" > <div class = "img_thumbnail productlist" > <img src= "{{ asset('img') }}/{{ $product->photo }}" class = "img-fluid" > <div class = "caption" > <h4>{{ $product ->product_name }}</h4> <p>{{ $product ->product_description }}</p> <p><strong>Price: </strong> ${{ $product ->price }}</p> <p class = "btn-holder" ><a href= "{{ route('add_to_cart', $product->id) }}" class = "btn btn-primary btn-block text-center" role= "button" >Add to cart</a> </p> </div> </div> </div> @ endforeach </div> @endsection |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 | //resources/views/cart.blade.php @ extends ( 'layout' ) @section( 'content' ) <table id= "cart" class = "table table-hover table-condensed" > <thead> <tr> <th style= "width:50%" >Product</th> <th style= "width:10%" >Price</th> <th style= "width:8%" >Quantity</th> <th style= "width:22%" class = "text-center" >Subtotal</th> <th style= "width:10%" ></th> </tr> </thead> <tbody> @php $total = 0 @endphp @ if (session( 'cart' )) @ foreach (session( 'cart' ) as $id => $details ) @php $total += $details [ 'price' ] * $details [ 'quantity' ] @endphp <tr data-id= "{{ $id }}" > <td data-th= "Product" > <div class = "row" > <div class = "col-sm-3 hidden-xs" ><img src= "{{ asset('img') }}/{{ $details['photo'] }}" width= "100" height= "100" class = "img-responsive" /></div> <div class = "col-sm-9" > <h4 class = "nomargin" >{{ $details [ 'product_name' ] }}</h4> </div> </div> </td> <td data-th= "Price" >${{ $details [ 'price' ] }}</td> <td data-th= "Quantity" > <input type= "number" value= "{{ $details['quantity'] }}" class = "form-control quantity cart_update" min= "1" /> </td> <td data-th= "Subtotal" class = "text-center" >${{ $details [ 'price' ] * $details [ 'quantity' ] }}</td> <td class = "actions" data-th= "" > <button class = "btn btn-danger btn-sm cart_remove" ><i class = "fa fa-trash-o" ></i> Delete </button> </td> </tr> @ endforeach @ endif </tbody> <tfoot> <tr> <td colspan= "5" class = "text-right" ><h3><strong>Total ${{ $total }}</strong></h3></td> </tr> <tr> <td colspan= "5" class = "text-right" > <a href= "{{ url('/') }}" class = "btn btn-danger" > <i class = "fa fa-arrow-left" ></i> Continue Shopping</a> <button class = "btn btn-success" ><i class = "fa fa-money" ></i> Checkout</button> </td> </tr> </tfoot> </table> @endsection @section( 'scripts' ) <script type= "text/javascript" > $( ".cart_update" ).change( function (e) { e.preventDefault(); var ele = $(this); $.ajax({ url: '{{ route(' update_cart ') }}' , method: "patch" , data: { _token: '{{ csrf_token() }}' , id: ele.parents( "tr" ).attr( "data-id" ), quantity: ele.parents( "tr" ).find( ".quantity" ).val() }, success: function (response) { window.location.reload(); } }); }); $( ".cart_remove" ).click( function (e) { e.preventDefault(); var ele = $(this); if (confirm( "Do you really want to remove?" )) { $.ajax({ url: '{{ route(' remove_from_cart ') }}' , method: "DELETE" , data: { _token: '{{ csrf_token() }}' , id: ele.parents( "tr" ).attr( "data-id" ) }, success: function (response) { window.location.reload(); } }); } }); </script> @endsection |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | //public/css/style.css body { background-color: #f6f6f6; } .img_thumbnail { position: relative; padding: 0px; margin-bottom: 20px; } .img_thumbnail img { width: 100%; } .img_thumbnail .caption{ margin: 7px; text-align: center; } .dropdown{ float:right; padding-right: 30px; } .btn{ border:0px; margin:10px 0px; box-shadow:none !important; } .dropdown .dropdown-menu{ padding:20px; top:30px !important; width:350px !important; left:-110px !important; box-shadow:0px 5px 30px black; } .total-header-section{ border-bottom:1px solid #d2d2d2; } .total-section p{ margin-bottom:20px; } .cart-detail{ padding:15px 0px; } .cart-detail-img img{ width:100%; height:100%; padding-left:15px; } .cart-detail-product p{ margin:0px; color:#000; font-weight:500; } .cart-detail .price{ font-size:12px; margin-right:10px; font-weight:500; } .cart-detail . count { color:#000; } .checkout{ border-top:1px solid #d2d2d2; padding-top: 15px; } .checkout .btn-primary{ border-radius:50px; } .dropdown-menu:before{ content: " " ; position:absolute; top:-20px; right:50px; border:10px solid transparent; border-bottom-color:#fff; } .productlist { box-shadow: 0px 10px 30px rgb(0 0 0 / 10%); border-radius: 10px; height: 100%; overflow: hidden; } |
routes/web.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | //routes/web.php <?php use Illuminate\Support\Facades\Route; use App\Http\Controllers\ProductsController; //Route::get('/', function () { // return view('welcome'); //}); Route::get( '/' , [ProductsController:: class , 'index' ]); Route::get( 'cart' , [ProductsController:: class , 'cart' ])->name( 'cart' ); Route::get( 'add-to-cart/{id}' , [ProductsController:: class , 'addToCart' ])->name( 'add_to_cart' ); Route::patch( 'update-cart' , [ProductsController:: class , 'update' ])->name( 'update_cart' ); Route:: delete ( 'remove-from-cart' , [ProductsController:: class , 'remove' ])->name( 'remove_from_cart' ); |
Starting Laravel development server: http://127.0.0.1:8000