/vue-flash

A Vue.js 2 Helpful Notification.

Primary LanguageJavaScript

Vue2 Flash

A Vue2 Flash Helpful Notification.

#Demo http://vueflash.sagaryonjan.com.np/

Install

npm install vue2-flash

In App main.js

import Vue from 'vue';
import VueFlash from 'vue2-flash';
Vue.use(VueFlash);

now you can simply call this

this.$flash.success.created(); //message: Data Created Successfully.

this.$flash.success.created({
  title : 'User',
  group: 'user-group' // group must be called in component to render
 });  

and add this component where ever you want to display.

 <flash-float></flash-float> // this will display in top right area
 <flash></flash> // this is normal like bootstrap alert

you can also normally call

    this.$flash.notify(type, message, group); 
   //type: success,
   //message: 'Data Created Successfully',
   //group: 'user-create'

U can define group to render notification you can add prop group in notification like :

    //Group Prop must be string
    <flash :group="'user-create'"></flash>

Props

All props are optional.

Name Type Default Description
group String 'sy-vue-notify' group name for component which will be render when called
duration Number 4000 Component will hide after 4000
classes String 'sy-vue-notify' Add you class
animation String '' animation type: fade,slide

In there is addition component

 name :area
 type : String
 default: 'top-right' 
 Area type :
 a. right :  top-right, middle-right, down-right,
 b. middle : top-middle, middle, down-middle
 c. left : top-left, middle-left, down-left

Additional Functionality

#Success 
1.this.$flash.success.created();
2.this.$flash.success.saved();
3.this.$flash.success.updated();
4.this.$flash.success.deleted();

#Warning
1.this.$flash.warning.accessDenied();
2.this.$flash.warning.invalidRequest();

#Info
1.this.$flash.info.welcome();

#Danger
1.this.$flash.danger.createdFailed();
2.this.$flash.danger.savedFailed();
3.this.$flash.danger.updatedFailed();
4.this.$flash.danger.deletedFailed();

You can also create your own method. If you want to create notify message which you will use many time as your app grow. Let assume you want to notify if some one is not authorized than :

 let options =  {
                warning: {
                    'unauthorized' : "You are not authorized"
                },
            };
            
 you can add warning,info,danger,success           
 
 Vue.use(VueFlash, options);
 
 // now you can call
 this.$flash.warning.unauthorized();

You can also use push function. It is going to push the data and set default value. So when you are working with spa and you want to send alert notification into another route in another component than you can use push which is going to set the default value.

this.$flash.push(type, message, group); 

you can also push in :

this.$flash.success.created('push'); 
this.$flash.success.saved('push'); 
this.$flash.success.updated('push'); 

When you use created function than it is going to send

message: Data Created Successfully. 

So if you want to update that data into User than you can call

this.$flash.success.created('User');  

If you also want to push than

this.$flash.success.created({
 type : 'push'
 title : 'User',
 group: 'user-group' // group must be called in component to render
});  

addtional attribute
You can also updated the message using message property. 

#Browser Include the script file, then install the component with Vue.use(VueFlash); e.g.:

<script type="text/javascript" src="node_modules/vuejs/dist/vue.min.js"></script>
<script type="text/javascript" src="node_modules/vue-clock-simple/dist/vue-flash.min.js"></script>
<script type="text/javascript">
  Vue.use(VueFlash);
</script>

#Module

import VueFlash from 'vue-flash';

You can test it in development with:

Run tests

npm run test

License

The MIT License (MIT). Please see License File for more information.