rb-cogo-toast
Version:
Beautiful, Zero Configuration, Toast Messages - Built with React
166 lines (116 loc) • 7.91 kB
Markdown
<p align="center"><a href="https://cogoport.github.io/cogo-toast/" target="_blank"><img src="https://cogoport.github.io/cogo-toast/meta/android-chrome-96x96.png" alt="cogo-toast" title="cogo-toast" width="120"></a></p>
<h1 align="center">Cogo Toast</h1>
<p align="center" style="font-size: 1.2rem;">Beautiful, Zero Configuration, Toast Messages for React ~4kb gzip (with styles and icons)</p>
<p align="center"><a href="https://cogoport.github.io/cogo-toast/">https://cogoport.github.io/cogo-toast/</a></p>
[](https://david-dm.org/Cogoport/cogo-toast.svg)
[](https://www.npmjs.com/package/cogo-toast)
[](https://unpkg.com/cogo-toast/dist/index.js)
[](https://www.npmjs.com/package/cogo-toast)

[](https://github.com/Cogoport/cogo-toast/blob/master/LICENSE)
<p align="center">
<a href="https://cogoport.github.io/cogo-toast/" target="_blank"><img src="docs/public/images/preview.gif" alt="cogo-toast-preview" title="cogo-toast-preview"></a>
</p>
### Install via NPM:
```bash
npm install --save cogo-toast
```
### Install via Yarn:
```bash
yarn add cogo-toast
```
#### Note:
The latest version `^3.0.0` makes the use of React Hooks internally.
To use this package in projects that don't support hooks, use `v2.0.1` instead.
```bash
yarn add cogo-toast@2.0.1
```
## Usage
Its Plug and Play. No configuration required. Just import and you are good to go.
```javascript
import cogoToast from 'cogo-toast';
cogoToast.success('This is a success message!');
```
### 5 Built in Types
There are 5 built-in types to handle the most common cases in any application.
```javascript
cogoToast.success('This is a success message');
cogoToast.info('This is a info message');
cogoToast.loading('This is a loading message');
cogoToast.warn('This is a warn message');
cogoToast.error('This is a error message');
```
### Use JSX
**cogoToast** is built using React. Which means any valid jsx can be used as the message in cogoToast
```javascript
cogoToast.info(
<div>
<b>Awesome!</b>
<div>Isn't it?</div>
</div>,
);
```
### Returns a Promise
Returns a promise which resolves when the toast is about to hide.
This can be useful to do some action when the toast has completed showing.
```javascript
cogoToast.loading('Loading your data...').then(() => {
cogoToast.success('Data Successfully Loaded');
});
```
### Hide on Click
```javascript
const { hide } = cogoToast.success('This is a success message.', {
onClick: () => {
hide();
},
});
```
### Completely Customizable
The second parameter to the function is an options object that can be passed in for customization.
```javascript
cogoToast.info('This is an info message', options);
```
#### All Available Options
Here's a list of all the available options, to customize the toast to your needs.
| Options | Type | Default |
| :-----------: | :----------------------------------------------------------------------------------------------: | :--------------------------------------------------------: |
| hideAfter | Number in Seconds | `3` <br />(Can be `0` to disable auto-hiding of the toast) |
| position | `'top-left', 'top-center', 'top-right',` <br /> `'bottom-left', 'bottom-center', 'bottom-right'` | `'top-center'` |
| heading | String | `''` |
| renderIcon | Function<ReactNode> | Icon Based on the Type |
| bar | Object <br /> `{ size: '2px', style: 'solid/dashed/dotted', color: '#hex' }` | Based on the Type |
| onClick() | Function | `null` |
| role | aria-role | `status` |
| toastContainerID | The dom element in which the toast container is added | `ct-container` |
### Custom Styling
You can provide your own custom styling by extending the `ct-toast` class in your css styles.
For all classnames, refer to [/src/styles/styles.css](/src/styles/styles.css)
#### Customize each type of Toast seperately
Customize each type of Toast seperately, by extending the `ct-toast-<type>` class. For example, in your CSS,
```
ct-toast-success {
color: #FFFFFF;
background: #6EC05F;
}
```
### Only ~ 4kb gzip (with Styles and Icons)
The package contains the minified build file, along with the SVG Icons and the Styles, built into the Code, with a total of only ~4kb gzip.
## Contributors ✨
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
<!-- prettier-ignore-start -->
<!-- markdownlint-disable -->
<table>
<tr>
<td align="center"><a href="https://github.com/anmdotdev"><img src="https://avatars2.githubusercontent.com/u/36692003?v=4" width="100px;" alt="Anmol Mahatpurkar"/><br /><sub><b>Anmol Mahatpurkar</b></sub></a><br /><a href="https://github.com/Cogoport/cogo-toast/commits?author=anmolmahatpurkar" title="Code">💻</a> <a href="#design-anmolmahatpurkar" title="Design">🎨</a> <a href="https://github.com/Cogoport/cogo-toast/commits?author=anmolmahatpurkar" title="Documentation">📖</a></td>
<td align="center"><a href="https://balazsorban.com"><img src="https://avatars1.githubusercontent.com/u/18369201?v=4" width="100px;" alt="Balázs Orbán"/><br /><sub><b>Balázs Orbán</b></sub></a><br /><a href="https://github.com/Cogoport/cogo-toast/commits?author=balazsorban44" title="Code">💻</a></td>
<td align="center"><a href="https://github.com/Keaws"><img src="https://avatars1.githubusercontent.com/u/5289466?v=4" width="100px;" alt="Vitalii Kalchuk"/><br /><sub><b>Vitalii Kalchuk</b></sub></a><br /><a href="https://github.com/Cogoport/cogo-toast/commits?author=Keaws" title="Code">💻</a></td>
<td align="center"><a href="http://www.apathak.com"><img src="https://avatars1.githubusercontent.com/u/24917309?v=4" width="100px;" alt="Amar Pathak"/><br /><sub><b>Amar Pathak</b></sub></a><br /><a href="https://github.com/Cogoport/cogo-toast/commits?author=amarpathak" title="Documentation">📖</a></td>
<td align="center"><a href="https://github.com/nataly87s"><img src="https://avatars2.githubusercontent.com/u/7895237?s=460&v=4" width="100px;" alt="Nataly Shrits"/><br /><sub><b>Nataly Shrits</b></sub></a><br /><a href="https://github.com/Cogoport/cogo-toast/commits?author=nataly87s" title="Code">💻</a></td>
</tr>
</table>
<!-- markdownlint-enable -->
<!-- prettier-ignore-end -->
<!-- ALL-CONTRIBUTORS-LIST:END -->
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!