devmi/flashy

VueJs alert component for laravel.

Installs: 195

Dependents: 0

Suggesters: 0

Security: 0

Stars: 4

Watchers: 2

Forks: 2

Language:Vue

2.0.1 2018-09-20 16:46 UTC

This package is auto-updated.

Last update: 2024-12-21 20:41:41 UTC


README

Beautiful alert component made with VueJs for Laravel app.

Overview

Flashy

Installation

Step 1: Composer

From the command line, run:

composer require devmi/flashy

Step 2: Service Provider

If you're using laravel >5.5 skip to the next step.

Open config/app.php and within the providers array:

Devmi\Flashy\FlashyServiceProvider::class

Step 3: Vendor Puslish

Now you must publish the vue compenent and register it in order to use it.

php artisan vendor:publish --tag=devmi

open resources/assets/js/app.js and register the component

Vue.component('flashy', require('./vendor/devmi/Flashy.vue'));

you find the file under resources/assets/js/vendor/devmi/Flashy.vue.

Step 3: Add Flashy Tag

You can add the flashy component anywhere in your blade files but preferably it should be added to your app.blade.php file

<flashy data-message="{{ flashy()->message() }}"></flashy>

Usage

Now in your controller before any redirect you may do

flashy()->push('This message will be flashed.');

The default color is bootstrap alert success.

More Control

You may also change the default theme color, display delay, add title, stop animation

app.blade.php

<flashy
    title="{{ flashy()->title() }}"
    message="{{ flashy()->message() }}"
    type="{{ flashy()->type() }}"
    delay="3000"
    animated="true"
>
</flashy>

And

flashy()->push(message, type, title);

Title: String (optional)

Message: String

Type: string eg: ['primary', 'success', 'danger', 'warning', 'secondary', 'black', 'light'] (optional) | Default: success

Delay: Integer (optional) | Default: 3000

Animated: Boolean (optional) | Default: true

Notice

If you use Ajax requests, you should add to resources/assets/js/app.js the following code

window.events = new Vue();
window.flashy = (message, type, title) => window.events.$emit('flashy', message, type, title)

then simply you can call flashy() global function from any .vue file and pass you arguments.

Issues and Contribution

If you find any bug or problem please open an issue or create a pull request, Thanks!.