ng-snotify
data:image/s3,"s3://crabby-images/1da34/1da349671a1795340c577710230f498155a7b36d" alt="NPM Downloads"
Example
https://artemsky.github.io/ng-snotify/
Installation
To install this library, run:
$ npm install ng-snotify -S
and then from your Angular AppModule
:
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import { SnotifyModule, SnotifyService } from 'ng-snotify';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
SnotifyModule
],
providers: [SnotifyService],
bootstrap: [AppComponent]
})
export class AppModule { }
Add app-snotify
component to you root component
<app-snotify></app-snotify>
Now you should inject SnotifyService
import {Component, OnInit} from '@angular/core';
import {SnotifyService} from 'ng-snotify';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit {
constructor(private snotifyService: SnotifyService) {}
ngOnInit() {
this.snotifyService.setConfig({
timeout: 30000
}, {
newOnTop: false,
});
}
addToast() {
this.snotifyService.error('Example error!', 'Here we are', {
closeOnClick: false
});
}
clearToasts() {
this.snotifyService.clear();
}
}
Configuration
Global Cofig (affects all toasts)
SnotifyService
has method setConfig
, wich takes 2 parametrs
1 - Object typeof SnotifyConfig
or null
export interface SnotifyConfig {
timeout?: number;
showProgressBar?: boolean;
type?: SnotifyType;
closeOnClick?: boolean;
pauseOnHover?: boolean;
buttons?: [SnotifyButton, SnotifyButton] | [SnotifyButton];
}
2 - Object typeof SnotifyOptions
or null
export interface SnotifyOptions {
maxOnScreen?: number;
newOnTop?: boolean;
position?: SnotifyPosition;
transition?: number;
}
Toast Config (affects current toast)
You can call toast by calling one of this methods from SnotifyService
instance
success(title: string, body: string, config?: SnotifyConfig): number
info(title: string, body: string, config?: SnotifyConfig): number
warning(title: string, body: string, config?: SnotifyConfig): number)
error(title: string, body: string, config?: SnotifyConfig): number)
simple(title: string, body: string, config?: SnotifyConfig): number
confirm(title: string, body: string, config: SnotifyConfig): number)
prompt(title: string, body: string, config: SnotifyConfig): number)
async(title: string, body: string, config: SnotifyConfig): number)
All toast methods return id
, so you can remove toast by calling snotifyService.remove(id)
If you call snotifyService. remove()
without id, it will affect all toasts, the same is snotifyService.clear()
######Here is an example
const id = snotifyService.simple('Example title!', 'Example body message', {
timeout: 0,
showProgressBar: true,
closeOnClick: false,
pauseOnHover: true
});
this.snotifyService.remove(id)
Callbacks (affects all toast)
There are few lifecycle hooks
onInit
- when toast has been shownonClick
- when toast has been clickedonHoverEnter
- on mouse enteronHoverLeave
- on mouse leavebeforeDestroy
- before toast destroyedafterDestroy
- after toast has been destroyed
You can set it with snotifyService
this.snotifyService.onInit = (toast: SnotifyToast) => {
};
All interfaces can be imported from ng-snotify
The best place to set global config is ngOnInit()
Documentation and Examples
Documentation - here.
Examples - here
Development
Go to develop branch and use angular-cli
License
MIT © artemsky