dongrim/laravel-toastr

Toast notifications for laravel 5.5+, 6 and 7

2.0.0 2022-05-30 09:19 UTC

This package is auto-updated.

Last update: 2024-12-29 06:58:32 UTC


README



Installation

1) Install the Toastr library (front end dependency)

1.1) Install Toastr via npm . Github | Demo

npm install toastr --save-dev

1.2) Require the js in resources/assets/js/bootstrap.js as window.toastr = require('toastr');

try {
  window.$ = window.jQuery = require('jquery');

  require('bootstrap');

  window.toastr = require('toastr');

} catch (e) { }

1.3) Import the sass in resources/assets/sass/app.scss as @import "~toastr/toastr"; then build via npm npm run prod.

// Fonts
@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,400i,700");

// Variables
@import "variables";

// Bootstrap
@import "~bootstrap/scss/bootstrap";

// Toastr
@import "~toastr/toastr";



2) Install dongrim/laravel-toastr

2.1) Run

composer require dongrim/laravel-toastr

2.2) Optional: Laravel 5.4 and below
Add Dongrim\Toastr\ToastrServiceProvider::class to providers in config/app.php.
Add 'Toastr' => Dongrim\Toastr\Facades\Toastr::class to aliases in config/app.php.

// config/app.php

'providers' => [
  // ...
  Dongrim\Toastr\ToastrServiceProvider::class,
],

'aliases' => [
  // ...
  'Toastr' => Dongrim\Toastr\Facades\Toastr::class,
],

2.3) Run php artisan vendor:publish --provider="Dongrim\Toastr\ToastrServiceProvider" to publish the config file in config/toastr.php


2.4) Add {!! Toastr::render() !!} Facade or {!! toastr()->render() !!} helper in your main view.


2.4) Get all messages {!! Toastr::messages() !!} Facade or {!! toastr()->messages() !!}

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <link rel="stylesheet" type="text/css" href="/css/app.css">
</head>
<body>
    <div id="app"></div>
    <script type="text/javascript" src="js/app.js"></script>
    {!! toastr()->render() !!}
</body>
</html>

2.5) Optional: Modify the publish configuration file locate at config/toastr.php to your liking.

<?php

return [

    'session_name' => 'toastr',

    'options' => [
        "closeButton" => true,
        "debug" => false,
        "newestOnTop" => false,
        "progressBar" => true,
        "positionClass" => "toast-bottom-right",
        "preventDuplicates" => false,
        "onclick" => null,
        "showDuration" => "300",
        "hideDuration" => "1000",
        "timeOut" => "10000",
        "extendedTimeOut" => "1000",
        "showEasing" => "swing",
        "hideEasing" => "linear",
        "showMethod" => "fadeIn",
        "hideMethod" => "fadeOut"
    ]

];



Usage

Use the Toastr facade Toastr:: or the helper function toast()-> to access the methods in this package.

Toastr::error(string $message, string $title = null, array $options = []);

toastr()->error(string $message, string $title = null, array $options = []);

Examples:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use TJGazel\Toastr\Facades\Toastr;

class DashboardController extends Controller
{

    public function index()
    {
        Toastr::info('welcome admin!');

        return view('dashoard.index');
    }
}

You can also chain multiple messages together using:

toastr()
    ->error('Unauthorized!', 'Error 401')
    ->info('Authentication required to access dashboard page', null, ['timeOut' => 15000]);

Note that in the 3rd parameter you can customize toastr options. See the config/toastr.php file for all possibilities.


All methods

toastr()->info();
toastr()->warning();
toastr()->success();
toastr()->error();

Tanks for:

Toastr
Laravel tjgazel/laravel-toastr