- Pertama-tama aktifkan xampp anda terlebih dahulu, ikuti langkah tutorial sebelumnya .
- Buka salah satu Web Browser Anda Google Chrome, Mozilla, dll. Lalu ketik http://localhost/dashboard/ pada link URL anda.
data:image/s3,"s3://crabby-images/fd01f/fd01fa5f8ab069f6bc74ee3f9c3782f2c6f43ab3" alt=""
3. Jika sudah muncul tampilan seperti gambar di atas, klik phpMyAdmin.
data:image/s3,"s3://crabby-images/4fb6e/4fb6e4b1d5a131bee72b99905deb67fdb57c7881" alt=""
4. Klik New.
data:image/s3,"s3://crabby-images/e99f2/e99f29ab480125374ccc9fe19d9988e9ba4ae8d7" alt=""
5. Isikan nama tabel dengan lara_store . Lalu klik Create.
data:image/s3,"s3://crabby-images/771f7/771f798c6bdba8c0ec553ec6877f8f793b57cc77" alt=""
6. Kemudian buka file .env di dalam folder LaraStore untuk pengaturan database, isi sesuai gambar di bawah
data:image/s3,"s3://crabby-images/9d14c/9d14c78c012e7613fcd34bcb59d4c4c8162409ef" alt=""
7. Sekarang, kita atur menu pada sidebar. Buka file sidebar.blade.php hapus baris code yg di block seperti gambar dibawah
data:image/s3,"s3://crabby-images/721e0/721e0506b1ea1e1b986a66b8c3c7902c70363dd2" alt=""
data:image/s3,"s3://crabby-images/4342f/4342fae48bbf889cf44e4e962cc15eaf5969d536" alt=""
8. Ubah baris code pada sidebar.blade.php seperti gambar dibawah
data:image/s3,"s3://crabby-images/a3062/a30625e54170b67d78d0b28cc6d272148e0d6a17" alt=""
9. Sekarang coba buka di browser nya, masukkan http://localhost/LaraStore/public/admin
data:image/s3,"s3://crabby-images/6e586/6e586c5b26684867dea06b02ef29c5d5fa7f3f1d" alt=""
10. Buatlah sebuah tabel dengan migration, menggunakan php artisan lewat cmd
data:image/s3,"s3://crabby-images/2eed3/2eed329da98ddf9095492c2315a9ec1097a1c25b" alt=""
11. Kemudian buka folder database/migrations/ cari file dengan akhiran create_products_table.php, masukkan code seperti gambar di bawah
data:image/s3,"s3://crabby-images/9d451/9d451ec0207289e9ce051a5bc64e15ffc15fe145" alt=""
12. Lalu hapus dua file paling atas dalam folder
database/migrations/
data:image/s3,"s3://crabby-images/e90cb/e90cb2b465093534a68a795a272a39c86fa8d139" alt=""
data:image/s3,"s3://crabby-images/3fc9a/3fc9a62e5ffebbd65ec36e040bcced6303c5dabd" alt=""
13. Gunakan perintah berikut untuk membuat tabel pada database
data:image/s3,"s3://crabby-images/9c510/9c5102c9095b0c2226e7fc00f13b7eabefcefa74" alt=""
apabila muncul keterangan seperti ini, maka tabel berhasil dibuat
data:image/s3,"s3://crabby-images/1b262/1b26298eedf44df2493979298ad7c75238ce235b" alt=""
14. Sekarang kita buat model dari Product, masukkan perintah berikut
data:image/s3,"s3://crabby-images/98f0f/98f0fa2ad24be12e5c4c7372d8d1bea5ac8df105" alt=""
15. Buatlah sebuah folder dengan nama product
data:image/s3,"s3://crabby-images/befef/befef4c4c71e642e6b6a5d9537b50d4116077651" alt=""
16. Install library tambahan untuk membuat form lebih mudah, masukkan perintah berikut
data:image/s3,"s3://crabby-images/b2751/b2751057b2787f97460a766628da44a801211ac0" alt=""
17. Sekarang kita atur dalam config/app.php tambahkan code berikut
data:image/s3,"s3://crabby-images/7a835/7a83530998d95a129f89c0a60c63e9b4a40a7f4c" alt=""
data:image/s3,"s3://crabby-images/f54ab/f54abfda0063497f6ad3219ed2b1668c380e3be7" alt=""
code diatas berada dalam ‘aliases’ =>
18. Buatlah sebuah file create.blade.php dalam folder product
data:image/s3,"s3://crabby-images/90809/908094eeb2cabba4396d2ecda925e9e45edcf230" alt=""
19. Masukkan code berikut ke dalam file create.blade.php
@extends('admin/admin')
@section('content')
<div class="row">
<div class="col-12">
{{ Form::open() }}
<div class="card">
<div class="card-header">
<h3 class="card-title">Tambah Barang</h3>
</div>
<div class="card-body">
@if(!empty($errors->all()))
<div class="alert alert-danger">
{{ Html::ul($errors->all())}}
</div>
@endif
<div class="row">
<div class="col-md-6">
<div class="form-group">
{{ Form::label('name', 'Nama Barang') }}
{{ Form::text('name', '', ['class'=>'form-control', 'placeholder'=>'Masukkan Nama Barang']) }}
</div>
<div class="form-group">
{{ Form::label('price', 'Harga Barang') }}
{{ Form::text('price', '', ['class'=>'form-control', 'placeholder'=>'Masukkan Harga Barang']) }}
</div>
</div>
<div class="col-md-6">
<div class="form-group">
{{ Form::label('condition', 'Kondisi Barang') }}
{{ Form::select('condition', ['baru'=>'baru', 'bekas'=>'bekas'], null,
['class'=>'form-control']) }}
</div>
<div class="form-group">
{{ Form::label('image', 'Gambar Barang') }}
{{ Form::file('imageFile', ['class'=>'form-control']) }}
</div>
</div>
</div>
<div class="row">
<div class="col-12">
{{ Form::label('description', 'Description') }}
{{ Form::textarea('description', '', ['class'=>'form-control', 'placeholder'=>'Enter description', 'rows'=>5]) }}
</div>
</div>
</div>
<div class="card-footer">
<a href="{{ URL::to('admin') }}" class="btn btn-outline-info">Kembali</a>
{{ Form::submit('Proses', ['class' => 'btn btn-primary pull-right']) }}
</div>
</div>
<!-- </form> -->
{{ Form::close() }}
</div>
</div>
@endsection
20. Sekarang kita buat Product controller , serta route Resource agar mempermudah penggunaan method.
data:image/s3,"s3://crabby-images/6943d/6943daeda62f883b2f80169322bf52a9a017e45e" alt=""
21. Tambahkan Route::resource seperti gambar di bawah
data:image/s3,"s3://crabby-images/79ce9/79ce98e8fee6e5637d6f129aaa587eec383dc44a" alt=""
22. Buka file ProductController.php tambahkan code dalam method create( ) seperti gambar dibawah
data:image/s3,"s3://crabby-images/021d3/021d3b32513b7d397993e295f4d05211689896ca" alt=""
23. Sekarang coba buka di browser nya, masukkan http://localhost/LaraStore/public/admin/product/create
data:image/s3,"s3://crabby-images/d2847/d28471b1dae8275a7a2e799e7519f488582daa6f" alt=""
24. Tambahkan code berikut pada file create.blade.php
data:image/s3,"s3://crabby-images/72360/72360be8816f3c9ae99192d931c24c81f7576c75" alt=""
25. Aktifkan folder public untuk menyimpan gambar
data:image/s3,"s3://crabby-images/80aee/80aee064dd856d723f0c8fc456ff643d217deafc" alt=""
26. Buka file ProductController.php tambahkan code seperti gambar di bawah
data:image/s3,"s3://crabby-images/5033e/5033e40de5599240aca2d6e53f19166396afaaec" alt=""
27. Buka file ProductController.php tambahkan code dalam method store( )
public function store(Request $request)
{
//
$rules =[
'name'=>'required',
'price'=>'required|integer',
'imageFile'=>'required|mimes:jpg,png,jpeg,JPG',
'description'=>'required'
];
$pesan=[
'name.required'=>'Nama Barang Tidak Boleh Kosong',
'price.required'=>'Harga Barang Tidak Boleh Kosong',
'imageFile.required'=>'Gambar Tidak Boleh Kosong',
'description.required'=>'Deskripsi Tidak Boleh Kosong'
];
$validator=Validator::make(Input::all(),$rules,$pesan);
//jika data ada yang kosong
if ($validator->fails()) {
//refresh halaman
return Redirect::to('admin/product/create')
->withErrors($validator);
}else{
$image=$request->file('imageFile')->store('productImages','public');
$product=new \App\Product;
$product->name=Input::get('name');
$product->condition=Input::get('condition');
$product->description=Input::get('description');
$product->price=Input::get('price');
$product->image=$image;
$product->save();
Session::flash('message','Product Stored');
return "Berhasil Input Barang";
}
}
28. Sekarang coba input data pada form tambah data, lihat apakah berhasil
data:image/s3,"s3://crabby-images/7a308/7a308b0a61bd0f368de986af3160bcb6b4123162" alt=""
data:image/s3,"s3://crabby-images/0cf7f/0cf7f0dc4908d79c3edb1fd0f3c29b51f1c89909" alt=""
data:image/s3,"s3://crabby-images/0431a/0431a17442f391f81bdc17207044eeb24cfbe61a" alt=""
29. Buatlah sebuah file index.blade.php dalam folder product
data:image/s3,"s3://crabby-images/75beb/75bebeda07528a60619f9e1ef4dd191957ec5ebc" alt=""
30. Masukkan code di bawah ini ke dalam index.blade.php
@extends('admin/admin')
@section('content')
<div class="row">
<div class="col-12">
<div class="card">
<div class="card-header">
<h3 class="card-title">Data Barang</h3>
<div class="card-tools">
<a href="{{ URL::to('/admin/product/create')}}" class="btn btn-tool">
<i class="fa fa-plus"></i>
Add
</a>
</div>
</div>
<div class="card-body">
@if (Session::has('message'))
<div id="alert-msg" class="alert alert-success alert-dismissible">
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
{{ Session::get('message') }}
</div>
@endif
<div class="row">
<div class="col-md-12">
<table class="table table-bordered table-hover">
<thead>
<tr class="text-center">
<th>ID</th>
<th>Nama</th>
<th>Harga</th>
<th>Deskripsi</th>
<th>Kondisi</th>
<th>Gambar</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
@foreach($products as $product)
<tr>
<td class="text-center">{{ $product['id'] }}</td>
<td>{{ $product['name'] }}</td>
<td>Rp. {{ $product['price'] }}</td>
<td>{{ $product['description'] }}</td>
<td>{{ $product['condition'] }}</td>
<td class="text-center"><img src="{{ asset('storage/'.$product['image']) }}" width="100"/></td>
<td class="text-center">
<form method="POST" action="{{ URL::to('/admin/product/'.$product['id']) }}">
{{ csrf_field() }}
<input type="hidden" name="_method" value="DELETE" />
<div class="btn-group">
<a class="btn btn-info" href="{{ URL::to('/admin/product/'.$product['id']) }}"><i class="fa fa-eye"></i></a>
<a class="btn btn-success" href="{{ URL::to('/admin/product/'.$product['id'].'/edit') }}"><i class="fa fa-pencil"></i></a>
<button type="submit" class="btn btn-danger"><i class="fa fa-trash"></i></button>
</div>
</form>
</td>
</tr>
@endforeach
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
31. Buka file ProductController.php tambahkan code dalam method index ( )
data:image/s3,"s3://crabby-images/9cc16/9cc16f380a45328d3a6a79d48fcf55ce86e230bf" alt=""
32. Sekarang coba buka di browser nya, masukkan http://localhost/LaraStore/public/admin/product/
data:image/s3,"s3://crabby-images/0023e/0023ee1cf31fe6f4dd29f9a7cd4ae98a2a286a44" alt=""
33. Buka file ProductController.php ubah code dalam method store ( )
data:image/s3,"s3://crabby-images/39ef5/39ef5f213f96b9bf75aec97a2b860ee364fff64b" alt=""
34. Buka file sidebar.blade.php ubah code seperti gambar di bawah
data:image/s3,"s3://crabby-images/5d61d/5d61d6859ee7fd3dc40aa791a6d82a3ecbb07925" alt=""
35. Sekarang kita akan menampilkan detail barang, buatlah sebuah file show.blade.php dalam folder product
data:image/s3,"s3://crabby-images/8ad75/8ad75f474e52e64efd0c92dd2626911d727e7501" alt=""
36. Buka file show.blade.php tambahkan code di bawah
@extends('admin/admin')
@section('content')
<div class="row">
<div class="col-12">
<div class="card">
<div class="card-header">
<h3 class="card-title">Detail Barang</h3>
</div>
<div class="card-body">
<div class="row">
<div class="col-md-12">
<img src="{{ asset('storage/'.$product['image']) }}"
height="200" width="100%"/>
</div>
</div>
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label for="name">Nama Barang</label>
<input id="name" type="text" value="{{ $product['name'] }}" class="form-control" disabled />
</div>
<div class="form-group">
<label for="price">Harga Barang</label>
<input id="price" type="text" value="{{ $product['price'] }}" class="form-control" disabled />
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label for="status">Kondisi Barang</label>
<input id="status" type="text" value="{{ $product['condition'] }}" class="form-control" disabled />
</div>
</div>
</div>
<div class="row">
<div class="col-md-12">
<div class="form-group">
<label for="description">Description</label>
<input id="description" type="text" value="{{ $product['description'] }}" class="form-control" disabled />
</div>
</div>
</div>
</div>
</div>
</div>
</div>
@endsection
37. Buka file ProductController.php tambahkan code dalam method show ( )
data:image/s3,"s3://crabby-images/163f7/163f72685d8b437c19541d257e724a8f6ca161bb" alt=""
38. Klik simbol mata dalam kolom aksi pada salah satu data
data:image/s3,"s3://crabby-images/e5070/e50709725619c3e45a5121915730c40afa6993a7" alt=""
data:image/s3,"s3://crabby-images/e2db5/e2db5814e40e12daa2ef34e7951172ed801f3566" alt=""
39. Sekarang kita akan membuat form untuk edit data, buatlah sebuah file edit.blade.php dalam folder product
data:image/s3,"s3://crabby-images/1a416/1a416f318c872d1d232dbb2731e3809348894140" alt=""
40. Buka file edit.blade.php tambahkan code di bawah
@extends('admin/admin')
@section('content')
<div class="row">
<div class="col-12">
{{ Form::model($product,['route'=>['product.update',$product['id']], 'files'=>true,'method'=>'PUT']) }}
<div class="card">
<div class="card-header">
<h3 class="card-title">Ubah Data Barang</h3>
</div>
<div class="card-body">
@if(!empty($errors->all()))
<div class="alert alert-danger">
{{ Html::ul($errors->all())}}
</div>
@endif
<div class="row">
<div class="col-md-12">
<img src="{{ asset('storage/'.$product['image'])}}" width="100%" height="200">
</div>
<div class="col-md-6">
<div class="form-group">
{{ Form::label('name', 'Nama Barang') }}
{{ Form::text('name', $product['name'], ['class'=>'form-control', 'placeholder'=>'Masukkan Nama Barang']) }}
</div>
<div class="form-group">
{{ Form::label('price', 'Harga Barang') }}
{{ Form::text('price', $product['price'], ['class'=>'form-control', 'placeholder'=>'Masukkan Harga Barang']) }}
</div>
</div>
<div class="col-md-6">
<div class="form-group">
{{ Form::label('condition', 'Kondisi Barang') }}
<select name="item_kind" class="form-control">
<option value="baru" {{ $product['condition']=='baru'?'selected':'' }}>Baru</option>
<option value="bekas" {{ $product['condition']=='bekas'?'selected':'' }}>Bekas</option>
</select>
</div>
<div class="form-group">
{{ Form::hidden('imagePath',$product['image'])}}
{{ Form::label('image', 'Image') }}
{{ Form::file('imageFile', ['class'=>'form-control']) }}
</div>
</div>
</div>
<div class="row">
<div class="col-12">
{{ Form::label('description', 'Description') }}
{{ Form::textarea('description', $product['description'], ['class'=>'form-control', 'placeholder'=>'Enter description', 'rows'=>5]) }}
</div>
</div>
</div>
<div class="card-footer">
<a href="{{ URL::to('admin/product') }}" class="btn btn-outline-info">Back</a>
{{ Form::submit('Proses', ['class' => 'btn btn-primary pull-right']) }}
</div>
</div>
<!-- </form> -->
{{ Form::close() }}
</div>
</div>
@endsection
41. Buka file ProductController.php tambahkan code dalam method edit ( )
data:image/s3,"s3://crabby-images/2e0ba/2e0ba810d0e07ee41af69ff818584ca65700b2ce" alt=""
42. Klik simbol pensil pada kolom aksi
data:image/s3,"s3://crabby-images/e5070/e50709725619c3e45a5121915730c40afa6993a7" alt=""
data:image/s3,"s3://crabby-images/43ac7/43ac75854d5cd5e7863c11f4ac0c8147981a005a" alt=""
43. Buka file ProductController.php tambahkan code dalam method update ( )
public function update(Request $request, $id)
{
//
$rules=[
'name'=>'required',
'price'=>'required|integer',
'description'=>'required',
];
$pesan=[
'name.required'=>'Nama Tidak Boleh Kosong!!',
'price.required'=>'Harga Tidak Boleh Kosong!!',
'description.required'=>'Deskripsi Barang Tidak Boleh Kosong!!',
];
$validator=Validator::make(Input::all(),$rules,$pesan);
if ($validator->fails()) {
return Redirect::to('admin/product/'.$id.'/edit')
->withErrors($validator);
}else{
$image="";
if (!$request->file('imageFile')) {
# code...
$image=Input::get('imagePath');
}else{
$image=$request->file('imageFile')->store('productImages','public');
}
$product=\App\Product::find($id);
$product->name=Input::get('name');
$product->condition=Input::get('condition');
$product->price=Input::get('price');
$product->description=Input::get('description');
$product->image=$image;
$product->save();
Session::flash('message','Data Barang Berhasil Diubah');
return Redirect::to('admin/product');
}
}
44. Sekarang coba anda ubah salah satu data barang
data:image/s3,"s3://crabby-images/13c2a/13c2af15cc83054a530ebd71221c20fd1f0e339c" alt=""
45. Terakhir kita aktifkan fungsi hapus, buka file ProductController.php tambahkan code dalam method delete ( )
data:image/s3,"s3://crabby-images/7f2f7/7f2f7e9ccaf69398021cf46a1d060cc458b1217f" alt=""
46. Coba hapus salah satu data dengan klik simbol tong sampah
data:image/s3,"s3://crabby-images/e5070/e50709725619c3e45a5121915730c40afa6993a7" alt=""
data:image/s3,"s3://crabby-images/23d1a/23d1afab059366eb2bc580838fd24cd7d904f691" alt=""
Pingback: TUTORIAL 3 : Register dan Login Menggunakan Laravel - Rumah Coding