# Toast - A Bootstrap 4.2+ jQuery plugin
* [About](#about)
* [Usage](#usage)
* [Live Example](https://OliveEuphoricTriggers--five-nine.repl.co)
* [Caveats](#caveats)
* [Roadmap](#roadmap)
* [Contributing](#contributing)
### About
As of Bootstrap 4.2, [toasts](https://getbootstrap.com/docs/4.2/components/toasts/) have been inroduced and the aim of this plugin is to make them easier to use.
### Usage
You can pass to the `$.toast` function an object with the settings for your toast which are as follows:
| Parameter |Description| Default | Values |
| ------------- |-----------| ------- |---------
| title | Shows in the top left corner of the toast header | 'Notice!'| |
| subtitle | Shows in the top right corner of the toast header | N/A | |
| content | Shows in the toast body | N/A |
| type | Determines the style of the toast based on Bootstrap styles | 'info' | 'info', 'success', 'warning', 'error'
| delay | Determines how the toast will show for | 3000
**Note:** If content is omitted, the toast will not have a `.toast-body` and can be used as a small snack which will be shown below in the examples. By default toasts will be positioned in the top right corner and will in the future (hopefully) have other position options.
```javascript
$.toast({
title: 'Toast',
subtitle: '11 mins ago',
content: 'Hello, world! This is a toast message.',
type: 'info',
delay: 5000
});
```
![Example #1](https://i.gyazo.com/20fbdf05b57af4a76e28f66047fe6591.png)
The respective markdown for the above would be:
```
Hello, world! This is a toast message.
```
To show a "snack" (a small version of the toast), simply omit the content property:
```javascript
$.toast({
title: 'A small bitesize snack, not a toast!',
type: 'info',
delay: 5000
});
```
![Example Snack](https://i.gyazo.com/e707a35836553aa9dec96025eb332ac1.png)
Now, onto the different types:
![Example #2](https://i.gyazo.com/20fbdf05b57af4a76e28f66047fe6591.png)
An 'info' toast
![Example #3](https://i.gyazo.com/51b708cb610e603f61b80a6008a45729.png)
A 'success' toast
![Example #4](https://i.gyazo.com/0844e5f70f1e73416fb38be134144844.png)
A 'warning' toast
![Example #5](https://i.gyazo.com/8ee70ce1203d112a9a30ac53e350d54d.png)
An 'error' toast
The toasts are stackable:
![Example #6](https://i.gyazo.com/da0e40283269c3c38de605b7c938fa95.png)
### Caveats
* The toast will remain in the DOM when hidden, I am working on a way to incorperate removing them from the DOM or reusing existing ones if left in, however, for the time being, you can use the following to remove the toast once it is hidden from the DOM:
```javascript
$(document).on('hidden.bs.toast', '.toast', function (e) {
$(this).remove();
});
```
### Roadmap
* Allow img in toast as is shown in the Bootstrap 4 documentation
* Allow the option to prevent stacking
* Allow the option to keep / remove from DOM
* Custom styling (rounded toasts, blocky toasts, custom background colours)
* Positioning of the actual toast
### Contributing
I am open to contributions and you could contribute in many ways:
* Request features
* Submit bug reports
* Submit pull requests
* Help by answering issues
* Tell us if you are using the plugin and the project