Tutorial Laravel 10 #7 : Edit dan Update Data ke Database


Tutorial Laravel 10 #7 : Edit dan Update Data ke Database

Halo teman-teman semuanya, pada artikel kali ini kita akan melanjutkan belajar bagaimana cara membuat proses edit dan update data ke dalam database di Laravel.

Nanti kita juga akan belajar bagaimana cara membuat kondisi apabila gambar diperbarui dan tidak diperbarui saat proses edit dan update.

Langkah 1 - Menambahkan Method Edit dan Update

Hal yang harus kita lakukan pertama kali adalah menambahkan 2 method di dalam controller, method tersebut adalah :

  • function edit - method yang digunakan untuk menampilkan halaman form edit data.
  • function update - method yang digunakan untuk memproses data yang akan diupdate ke dalam database.

Silahkan teman-teman buka file app/Http/Controllers/PostController.php, kemudian ubah semua kode-nya menjadi seperti berikut ini.

app/Http/Controllers/PostController.php

<?php

namespace App\Http\Controllers;

//import Model "Post
use App\Models\Post;

use Illuminate\Http\Request;

//return type View
use Illuminate\View\View;

//return type redirectResponse
use Illuminate\Http\RedirectResponse;

//import Facade "Storage"
use Illuminate\Support\Facades\Storage;

class PostController extends Controller
{
    /**
     * index
     *
     * @return View
     */
    public function index(): View
    {
        //get posts
        $posts = Post::latest()->paginate(5);

        //render view with posts
        return view('posts.index', compact('posts'));
    }

    /**
     * index
     *
     * @return View
     */
    public function create(): View
    {
        return view('posts.create');
    }

    /**
     * store
     *
     * @param  mixed $request
     * @return RedirectResponse
     */
    public function store(Request $request): RedirectResponse
    {
        //validate form
        $this->validate($request, [
            'image'     => 'required|image|mimes:jpeg,jpg,png|max:2048',
            'title'     => 'required|min:5',
            'content'   => 'required|min:10'
        ]);

        //upload image
        $image = $request->file('image');
        $image->storeAs('public/posts', $image->hashName());

        //create post
        Post::create([
            'image'     => $image->hashName(),
            'title'     => $request->title,
            'content'   => $request->content
        ]);

        //redirect to index
        return redirect()->route('posts.index')->with(['success' => 'Data Berhasil Disimpan!']);
    }
    
    /**
     * show
     *
     * @param  mixed $id
     * @return View
     */
    public function show(string $id): View
    {
        //get post by ID
        $post = Post::findOrFail($id);

        //render view with post
        return view('posts.show', compact('post'));
    }
  
    /**
     * edit
     *
     * @param  mixed $id
     * @return View
     */
    public function edit(string $id): View
    {
        //get post by ID
        $post = Post::findOrFail($id);

        //render view with post
        return view('posts.edit', compact('post'));
    }
    
    /**
     * update
     *
     * @param  mixed $request
     * @param  mixed $id
     * @return RedirectResponse
     */
    public function update(Request $request, $id): RedirectResponse
    {
        //validate form
        $this->validate($request, [
            'image'     => 'image|mimes:jpeg,jpg,png|max:2048',
            'title'     => 'required|min:5',
            'content'   => 'required|min:10'
        ]);

        //get post by ID
        $post = Post::findOrFail($id);

        //check if image is uploaded
        if ($request->hasFile('image')) {

            //upload new image
            $image = $request->file('image');
            $image->storeAs('public/posts', $image->hashName());

            //delete old image
            Storage::delete('public/posts/'.$post->image);

            //update post with new image
            $post->update([
                'image'     => $image->hashName(),
                'title'     => $request->title,
                'content'   => $request->content
            ]);

        } else {

            //update post without image
            $post->update([
                'title'     => $request->title,
                'content'   => $request->content
            ]);
        }

        //redirect to index
        return redirect()->route('posts.index')->with(['success' => 'Data Berhasil Diubah!']);
    }
}

Dari perubahan kode di atas, pertama-tama kita import dulu Facade Storage dari Laravel. Ini akan kita gunakan nantinya untuk menghapus file gambar yang ada di dalam Laravel.

//import Facade "Storage"
use Illuminate\Support\Facades\Storage;

Kemudian kita buat method baru dengan nama edit dan di dalamnya kita berikan parameter $id. Method ini kode-nya hampir sama dengan method show, karena tujuannya sama-sama untuk menampilkan detail data berdasarkan ID.

public function edit(string $id): View
{

	//...
	
}

Di dalam method tersebut, kita lakukan get data post berdasarkan ID yang diambil dari parameter atau variable $id.

//get post by ID
$post = Post::findOrFail($id);

Jika data ditemukan, maka kita kirimkan ke dalam view menggunakan fungsi compact.

//render view with post
return view('posts.edit', compact('post'));

Setelah itu, kita buat method lagi dengan nama update. Method inilah yang digunakan untuk memproses data yang akan diupdate ke dalam database.

public function update(Request $request, $id): RedirectResponse
{

	//...
	
}

Di dalam method tersebut, pertama-tama kita buat validasi terlebih dahulu, sama seperti yang ada di dalam method store. Beda-nya hanya pada validasi image kita tidak memberikan rule required, karena image disini tidak wajib diupdate data-nya.

//validate form
$this->validate($request, [
    'image'     => 'image|mimes:jpeg,jpg,png|max:2048',
    'title'     => 'required|min:5',
    'content'   => 'required|min:10'
]);

Dari penambahan validasi di atas, kurang lebih seperti berikut ini penjelasannya.

KEY VALIDATION KETERANGAN
image image field harus berupa gambar
mimes:jpeg,jpg,png filed harus memiliki extensi jpeg, jpg dan png.
max:2048 field maksimal berukuran 2048 Mb / 2Mb.
title required field wajib diisi.
min:5 field minimal memiliki 5 karakter/huruf.
content required field wajib diisi.
min:10 field minimal memiliki 10 karakter/huruf.

Jika data yang dikirimkan sudah sesuai dengan validasi di atas, maka kita lanjutkan mencari data berdasarkan ID yang diambil dari parameter.

//get post by ID
$post = Post::findOrFail($id);

Tujuannya, agar nanti kita bisa mengambil object dari data di atas dan bisa digunakan untuk melakukan proses update data.

Setelah itu, kita membuat kondisi untuk memastikan apakah ada sebuah request file yang bernama image.

//check if image is uploaded
if ($request->hasFile('image')) {

	//upload gambar baru
	
	//hapus gambar lama
	
	//update data ke database
	
} else {

	//update data ke database

}

Di atas, jika ada request file dengan nama image, artinya kita akan melakukan upload gambar baru.

//upload new image
$image = $request->file('image');
$image->storeAs('public/posts', $image->hashName());

Kemudian kita hapus gambar yang lama di dalam Laravel menggunakan Storage::delete.

//delete old image
 Storage::delete('public/posts/'.$post->image);

Dan kita lakukan update data ke dalam database dengan menyertakan gambar yang baru.

//update post with new image
$post->update([
    'image'     => $image->hashName(),
    'title'     => $request->title,
    'content'   => $request->content
]);

Tapi jika tidak ada request file dengan nama image, maka kita cukup melakukan update data ke dalam database untuk title dan content saja.

//update post without image
$post->update([
    'title'     => $request->title,
    'content'   => $request->content
]);

Setelah itu, kita redirect atau arahkan ke route yang bernama posts.index dengan menambahkan session flash data dengan key success dan memiliki value Data Berhasil Diubah!.

//redirect to index
return redirect()->route('posts.index')->with(['success' => 'Data Berhasil Diubah!']);

Langkah 2 - Membuat View Form Edit

Setelah berhasil menambahkan 2 method di dalam controller, maka sekarang kita akan lanjutkan membuat view yang digunakan untuk menampilkan halaman form edit.

Silahkan teman-teman buat file baru dengan nama edit.blade.php di dalam folder resources/views/posts, kemudian masukkan kode berikut ini di dalamnya.

resources/views/posts/edit.blade.php

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Edit Data Post - SantriKoding.com</title>
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body style="background: lightgray">

    <div class="container mt-5 mb-5">
        <div class="row">
            <div class="col-md-12">
                <div class="card border-0 shadow-sm rounded">
                    <div class="card-body">
                        <form action="{{ route('posts.update', $post->id) }}" method="POST" enctype="multipart/form-data">
                            @csrf
                            @method('PUT')

                            <div class="form-group">
                                <label class="font-weight-bold">GAMBAR</label>
                                <input type="file" class="form-control" name="image">
                            </div>

                            <div class="form-group">
                                <label class="font-weight-bold">JUDUL</label>
                                <input type="text" class="form-control @error('title') is-invalid @enderror" name="title" value="{{ old('title', $post->title) }}" placeholder="Masukkan Judul Post">
                            
                                <!-- error message untuk title -->
                                @error('title')
                                    <div class="alert alert-danger mt-2">
                                        {{ $message }}
                                    </div>
                                @enderror
                            </div>

                            <div class="form-group">
                                <label class="font-weight-bold">KONTEN</label>
                                <textarea class="form-control @error('content') is-invalid @enderror" name="content" rows="5" placeholder="Masukkan Konten Post">{{ old('content', $post->content) }}</textarea>
                            
                                <!-- error message untuk content -->
                                @error('content')
                                    <div class="alert alert-danger mt-2">
                                        {{ $message }}
                                    </div>
                                @enderror
                            </div>

                            <button type="submit" class="btn btn-md btn-primary">UPDATE</button>
                            <button type="reset" class="btn btn-md btn-warning">RESET</button>

                        </form> 
                    </div>
                </div>
            </div>
        </div>
    </div>
    
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script>
<script src="https://cdn.ckeditor.com/4.13.1/standard/ckeditor.js"></script>
<script>
    CKEDITOR.replace( 'content' );
</script>
</body>
</html>

Pada penambahan kode di atas, untuk menampilkan data pada form, kita cukup memanggil object-nya dan menaruhnya di dalam attribute value dan helper old. Contohnya seperti berikut ini.

value="{{ old('title', $post->title) }}"

Dan karena content berada di dalam textarea, maka kita tidak perlu menggunakan attribute value untuk menampilkannya.

{{ old('content', $post->content) }}

Kemudian untuk form action kita arahkan ke dalam route yang bernama posts.update dan kita berikan parameter ID.

<form action="{{ route('posts.update', $post->id) }}" method="POST" enctype="multipart/form-data">

	//...
	
</form>

Route posts.update akan otomatis mengarah ke dalam method update yang ada di dalam controller.

Dan jangan lupa, untuk form edit kita wajib menambahkan @method('PUT'). Itu bertujuan untuk memberitahu bahwa method yang akan digunakan adalah PUT.

Langkah 3 - Uji Coba Edit dan Update Data

Silahkan teman-teman klik button EDIT yang ada pada halaman posts index, jika berhasil maka akan menampilkan halaman form edit yang kurang lebih seperti berikut ini.

Silahkan ubah-ubah isi di dalamnya sesuai dengan keinginan dan klik button Update, jika berhasil maka kurang lebih seperti berikut ini.

Mungkin cukup sampai sini materi tentang bagaimana cara membuat proses edit dan juga update data di Laravel beserta upload gambar.

Pada artikel berikutnya, kita semua akan belajar bersama-sama bagaimana cara membuat proses delete data dari database di dalam Laravel.

Terima Kasih



Fika Ridaul Maulayya
Full-Stack Developer, Content Creator and CO-Founder SantriKoding.com

Suka dengan tulisan di SantriKoding? Kamu bisa memberikan dukungan dengan berdonasi atau bagikan konten ini di sosial media. Terima kasih atas dukungan Anda!

KEBIJAKAN KOMENTAR

Saat memberikan komenatar silahkan memberikan informasi lengkap tentang error, seperti: screenshot, link kode, dll. Baca aturan komentar kami