Examples
Toasts
Simple, Success, Info, Warning, Error
service.success('Example body content');
service.success('Example body content', 'Example Title');
service.success('Example body content', {
timeout: 2000,
showProgressBar: false,
closeOnClick: false,
pauseOnHover: true
});
service.success('Example body content', 'Example title', {
timeout: 2000,
showProgressBar: false,
closeOnClick: false,
pauseOnHover: true
});
Async
Success
You should pass Promise of type Snotify to change some data or do some other actions
const successAction = Observable.create(observer => {
setTimeout(() => {
observer.next({
body: 'Still loading.....',
});
}, 2000);
setTimeout(() => {
observer.next({
title: 'Success',
body: 'Example. Data loaded!',
config: {
closeOnClick: true,
timeout: 5000,
showProgressBar: true
}
});
observer.complete();
}, 5000);
});
this.snotifyService.async('This will resolve with success', successAction, config);
Error
const errorAction = Observable.create(observer => {
setTimeout(() => {
observer.error({
title: 'Error',
body: 'Example. Error 404. Service not found',
});
}, 2000);
});
service.async('This will resolve with error', 'Async', errorAction);
Prompt & Validation
const yesAction = (toast: SnotifyToast) => {
if (!toast.value.match('snotify')) {
toast.valid = false;
return false;
} else {
toast.valid = true; // default value
service.remove(toast.id)
}
}
const noAction = (toast: SnotifyToast) => {
service.remove(toast.id) // default
}
service.prompt('Example body content', 'Example title', {
buttons: [
{text: 'Yes', action: yesAction, bold: true },
{text: 'No', action: noAction },
],
placeholder: 'This is the example placeholder which you can pass'
});
Confirm
service.confirm('Example body content', 'Example title', {
timeout: 5000,
showProgressBar: true,
closeOnClick: false,
pauseOnHover: true,
buttons: [
{text: 'Yes', action: () => console.log('Clicked: Yes'), bold: false},
{text: 'No', action: () => console.log('Clicked: No')},
{text: 'Later', action: (toast) => {console.log('Clicked: Later'); service.remove(toast.id); } },
{text: 'Close', action: (toast) => {console.log('Clicked: No'); service.remove(toast.id); }, bold: true},
]
});
Html
service.html(`<div class="snotifyToast__title"><b>Html Bold Title</b></div>
<div class="snotifyToast__body"><i>Html</i> <b>toast</b> <u>content</u></div> `, {
timeout: 5000,
showProgressBar: true,
closeOnClick: false,
pauseOnHover: true,
});
Callbacks
toast.on('mounted', (toast) => {
console.log('[CALLBACK]: mounted', toast)
});
toast.on('input', (toast) => {
if (!toast.value.match('snotify')) {
toast.valid = false;
return false;
} else {
toast.valid = true; // default value
service.remove(toast.id)
}
});
Custom icon
Icon viewport is set to 48x48 pixels.
service.simple('Example body content', 'Example title!', {
timeout: 2000,
showProgressBar: false,
closeOnClick: true,
icon: 'assets/custom-svg.svg'
});
Of course you can pass an url, for example http://placeholde.it/48x100
(this resource will generate us an image with 48x100 dimension).
And apply object-fit
to .snotify-icon
class in your styles
.snotify-icon {
object-fit: cover;
width: 100%;
height: 100%;
object-position: center;
}