How To Use SweetAlert2 In Laravel 11 For Confirming Deletions

How To Use SweetAlert2 In Laravel 11 For Confirming Deletions

November 23, 2024
Written By Sumeet Shroff
Learn to use Laravel 11 SweetAlert2 for confirming deletions by checking the result.value and initiating a delete value if user confirmation is received.

Web Design & Creative, Mobile Development, Affordable Services

Introduction: Why SweetAlert2 is a Game-Changer for Laravel 11

In web development, user interaction plays a critical role in shaping user experience. When it comes to confirming deletions, providing a clear and visually appealing prompt is crucial. Laravel 11, a robust PHP framework, combined with SweetAlert2, an elegant and feature-rich JavaScript library, makes this task seamless.

In this blog, we'll delve into how you can integrate SweetAlert2 in Laravel 11 to handle confirmation prompts for deletions. Not only will we simplify the process, but we'll also show you why this combination is a game-changer for developers and businesses alike.


What is SweetAlert2?

SweetAlert2 is an upgraded, more customizable version of the original SweetAlert library. It provides developers with a clean, modern design for alerts, confirmation boxes, and even custom modals. Unlike default browser alerts, SweetAlert2 lets you:

  • Style your alerts with CSS and themes.
  • Add buttons, animations, and custom icons.
  • Handle asynchronous operations, making it perfect for dynamic frameworks like Laravel.

For small businesses, using such tools ensures that their web apps are not just functional but also visually appealing.


Setting Up Laravel 11 for SweetAlert2

Before we dive into coding, you’ll need to set up your Laravel 11 project with SweetAlert2. Here's a step-by-step guide:

1. Install a Fresh Laravel 11 Application

If you’re starting from scratch, run:

composer create-project <a href="/blog/in-laravel-how-to-use-partial-template">laravel</a>/<a href="/blog/best-laravel-packages-to-build-powerful-crm-applications">laravel</a> <a href="/blog/using-faker-in-laravel-to-generate-random-dates">laravel</a>-sweetalert

This will set up a clean Laravel 11 environment.


2. Install SweetAlert2 via NPM

Laravel supports Node.js packages, so installing SweetAlert2 is straightforward:

npm install sweetalert2

Once installed, make sure to compile the assets by running:

npm run dev

3. Include SweetAlert2 in Your JavaScript

After installation, you need to import SweetAlert2 into your application. Open resources/js/app.js and add:

import Swal from "sweetalert2";
window.Swal = Swal;

Finally, compile your changes:

npm run dev

Creating a Laravel Route and Controller for Deletions

To demonstrate SweetAlert2 in Laravel 11, let’s create a basic example for deleting a record.

1. Define the Route

In routes/web.php, add:

use App\Http\Controllers\ItemController;

Route::get('/items', [ItemController::class, 'index']);
Route::delete('/items/{id}', [ItemController::class, 'destroy'])->name('items.destroy');

2. Create the Controller

Run the Artisan command to generate a controller:

php artisan make:controller ItemController

In ItemController.php, add methods to display and delete items:

public function index()
{
    $items = Item::all();
    return view('items.index', compact('items'));
}

public function destroy($id)
{
    $item = Item::findOrFail($id);
    $item->delete();

    return response()->json(['success' => 'Item deleted successfully!']);
}

Setting Up the Frontend for SweetAlert2 Integration

Now that the backend is ready, let’s create the frontend to implement SweetAlert2 for deletion confirmation.

1. Create the Blade File

In resources/views/items/index.blade.php, create the following structure:

@extends('layouts.app') @section('content')
<div class="container">
  <h1>Items List</h1>
  <table class="table">
    <thead>
      <tr>
        <th>ID</th>
        <th>Name</th>
        <th>Actions</th>
      </tr>
    </thead>
    <tbody>
      @foreach($items as $item)
      <tr>
        <td>{{ $item->id }}</td>
        <td>{{ $item->name }}</td>
        <td>
          <button class="btn btn-danger btn-delete" data-id="{{ $item->id }}">
            Delete
          </button>
        </td>
      </tr>
      @endforeach
    </tbody>
  </table>
</div>
@endsection

2. Add the SweetAlert2 Script

In the same Blade file, add a script section for handling the delete confirmation:

<script>
    document.querySelectorAll('.btn-delete').forEach(button => {
        button.addEventListener('click', function () {
            const id = this.dataset.id;

            Swal.fire({
                title: 'Are you sure?',
                text: "You won't be able to revert this!",
                icon: 'warning',
                showCancelButton: true,
                confirmButtonColor: '#3085d6',
                cancelButtonColor: '#d33',
                confirmButtonText: 'Yes, delete it!'
            }).then((result) => {
                if (result.value) {
                    fetch(`/items/${id}`, {
                        method: 'DELETE',
                        headers: {
                            'X-CSRF-TOKEN': document.querySelector('meta[name="csrf-token"]').getAttribute('content')
                        }
                    }).then(response => response.json())
                      .then(data => {
                          if (data.success) {
                              Swal.fire('Deleted!', data.success, 'success');
                              location.reload();
                          }
                      });
                }
            });
        });
    });
</script>

How SweetAlert2 Enhances User Experience in Laravel 11

  1. Visual Appeal: Default browser alerts are dull. SweetAlert2 provides elegant, modern designs that align with your site's branding.

  2. Improved Usability: Features like custom buttons, animations, and icons make your app more intuitive.

  3. Asynchronous Support: The ability to work with promises makes SweetAlert2 perfect for AJAX-based Laravel apps.


Prateeksha Web Design: Empowering Small Businesses with Laravel 11 and SweetAlert2

At Prateeksha Web Design, we specialize in creating modern web applications that balance functionality with aesthetic appeal. Our expertise in Laravel ensures that small businesses can leverage the latest technologies like SweetAlert2 to enhance their digital platforms.

If you’re looking for a team to build your next project or optimize an existing one, Prateeksha Web Design is here to help.


Conclusion

Using SweetAlert2 in Laravel 11 for confirming deletions not only makes your app more user-friendly but also adds a layer of professionalism to its design. From the value of result.value to the elegance of delete prompts, this guide has covered everything you need to get started.

Reach out to Prateeksha Web Design to see how we can transform your ideas into impactful solutions. With our help, even complex tasks like deletion confirmation can become opportunities to delight your users.

About Prateeksha Web Design

Prateeksha Web Design offers comprehensive services to teach clients how to use SweetAlert2 in Laravel 11 for confirming deletions. This includes detailed guidance on integrating SweetAlert2 into Laravel, setting up the confirmation mechanism, as well as testing and troubleshooting. The service also includes on-demand support and code review to ensure smooth implementation.

Interested in learning more? Contact us today.

Sumeet Shroff
Sumeet Shroff
Sumeet Shroff is a skilled author and expert in Laravel 11, specializing in the utilization of SweetAlert 2 result.value for confirming deletions.
Loading...