Laravel 9 Bootstrap Growl jQuery Notification Plugin

Reading Time: 5 minutes
2,196 Views

While doing any operation in any application we want some confirmation alerts like for success, warning, error, etc. Why we need these? It’s because it gives a more readable power to end users to understand what’s happening.

Bootstrap Growl jQuery Notification is a jQuery plugin. It gives plugin files likes of CSS and JS. When we add these files to application we can integrate Bootstrap notification for messages.

Inside this article we will see the concept of Laravel 9 Bootstrap Growl jQuery Notification plugin inside application. This is not laravel 9 application specific. You can use in any application of PHP.

This article will cover about using Bootstrap growl jquery plugin for message notifications to end user.

Learn More –

Let’s get started.

Laravel Installation

Open terminal and run this command to create a laravel project.

composer create-project laravel/laravel myblog

It will create a project folder with name myblog inside your local system.

To start the development server of laravel –

php artisan serve

URL: http://127.0.0.1:8000

Assuming laravel already installed inside your system.

Bootstrap Growl Plugin Files

Bootstrap Growl is a jQuery plugin. This plugin works when we use plugin files inside application. It provides CSS & JS files.

Plugin JS Link

# URL
https://cdnjs.cloudflare.com/ajax/libs/bootstrap-growl/1.0.0/jquery.bootstrap-growl.min.js

# Tag
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-growl/1.0.0/jquery.bootstrap-growl.min.js"></script>

Bootstrap CSS Link

# URL
https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css

# Tag
<link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">

When we link these files with application, then we will able to use the methods of Bootstrap Growl Plugin.

$.bootstrapGrowl("<Message Here>", {})

Create Controller

Back to project terminal and run this artisan command.

$ php artisan make:controller SiteController

It will create a file SiteController.php inside /app/Http/Controllers folder.

Open SiteController.php and write this code into it.

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

class SiteController extends Controller
{
    public function showGrowlMessages(){

        // Flash messages settings
       
        session()->flash("success", "This is success message");
   
        session()->flash("warning", "This is warning message");
   
        session()->flash("info", "This is information message");
   
        session()->flash("error", "This is error message");
   
        return view("growl-notification");
      }
}

Here,

We stored each level of messages into it’s key. Like we have messages for success, error, warning, etc. These messages only for demonstration. You can change it according to need.

Create Template

Create a file growl-notification.blade.php inside /resources/views folder.

Open template file and write this code into it.

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet">

<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>  
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-growl/1.0.0/jquery.bootstrap-growl.min.js"></script>


<script>
$(function(){

    @if(Session::has('success'))
        $.bootstrapGrowl('{{ Session::get("success") }}',{
            type: 'success',
            delay: 4000,
        });
    @endif

    @if(Session::has('error'))
        $.bootstrapGrowl('{{ Session::get("error") }}',{
            type: 'danger',
            delay: 4000,
        });
    @endif

    @if(Session::has('info'))
        $.bootstrapGrowl('{{ Session::get("info") }}',{
            type: 'info',
            delay: 4000,
        });
    @endif

    @if(Session::has('warning'))
        $.bootstrapGrowl('{{ Session::get("warning") }}',{
            type: 'warning',
            delay: 4000,
        });
    @endif
});
</script>

Concept

Reading session stored flash message and display it into a growl notification level.

@if(Session::has('success'))
    $.bootstrapGrowl('{{ Session::get("success") }}',{
        type: 'success',
        delay: 4000,
    });
@endif

Add Route

Open web.php from /routes folder. Add this route into it.

//...
use App\Http\Controllers\SiteController;

//...
Route::get('growl-notification', [SiteController::class, 'showGrowlMessages']);

Application Testing

Run this command into project terminal to start development server,

php artisan serve

URL: http://127.0.0.1:8000/growl-notification

Plugin Error If not Linked Properly

If you miss the plugin files to attach before use it in a correct way, then at console developers tab you will get some plugin errors.

$.bootstrapGrowl is not a function

We hope this article helped you to learn about Laravel 9 Bootstrap Growl jQuery Notification Plugin Tutorial in a very detailed way.

Online Web Tutor invites you to try Skillshike! Learn CakePHP, Laravel, CodeIgniter, Node Js, MySQL, Authentication, RESTful Web Services, etc into a depth level. Master the Coding Skills to Become an Expert in PHP Web Development. So, Search your favourite course and enroll now.

If you liked this article, then please subscribe to our YouTube Channel for PHP & it’s framework, WordPress, Node Js video tutorials. You can also find us on Twitter and Facebook.