Package Exports
- breadstick
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (breadstick) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Breadstick
A simple but flexible implementation of toast style notifications for Vue.js
- Inspired by React's toasted-notes
๐ Features
- An imperative API. This means that you don't need to set component state or render elements to trigger notifications. Instead, just call a function. This makes it very user friendly for component library authors.
- Render whatever you want. Utilize the render callback to create entirely custom notifications.
- Functional default styles. Import the provided css for some nice styling defaults or write your own styles.
โก๏ธ Installation
yarn install breadstick
or
npm install breadstick --save
You can then register breadstick
as a plugin.
import Vue from 'vue'
import Breadstick from 'breadstick'
Vue.use(Breadstick)
// You can now access the `breadstick` instance
// via `this.$breadstick` in your application.
You can also use breadstick's useBreadstick
API without the plugin architecture. This is useful for building UI component libraries.
import { useBreadstick } from 'breadstick'
const breadstick = useBreadstick()
// You can now access the `breadstick` instance
// via `breadstick` in your application.
๐ How it works
Simply import and create a new breadstick
instance and call the notify
method. Breadstick will expose a render
function API that you can use to render custom notifications inside of breadstick. Alternatively you can also use plain JSX to call the notify method.
Rendering custom components inside of breadstick gives component library authors flexibility with styling of notifications. This works well with design systems too. The render function/JSX API exposes the exact same render function used inside of Vue templates so all other component options are accessible.
๐คExamples
Breadstick's API only works with Vue's render function or JSX API to render custom components inside of notifications.
๐ With basic string messsage
this.$breadstick.notify('๐ฅ Show me the pancakes')
// With options:
this.$breadstick.notify('๐ฅ Show me the pancakes', {
position: 'top' || 'bottom' || 'top-left' || 'top-right' || 'bottom-left' || 'bottom-right',
duration: 8000 // Default is 5000
})
๐ฎ With Vue's render
function callback
import Alert from './components/Alert'
import breadstick from 'breadstick'
export default {
name: 'app',
mounted () {
// Breadstick renders your custom `Alert` component
this.$breadstick.notify(({ h, onClose }) => {
return h(Alert, {
on: {
click: onClose
}
}, 'A render function Alert notification')
})
}
}
๐ With JSX
import Alert from './components/Alert'
import breadstick from 'breadstick'
export default {
name: 'app',
mounted () {
const showAlert = () => alert('Hello!')
// Breadstick renders your custom `Alert` component
breadstick.notify(({ onClose }) => {
return (
<Alert onClick={onClose}>
An JSX Alert notification
</Alert>
)
}
}
๐ To do:
- Self implemented portal
- Expose
toaster
API to client and render components by callingtoaster.notify
. - Implement animations API for toast entry/exit.
- Clear notifications API
- Docs
- Setup Vuepress for documentation
- Netlify Demo
- Publish to NPM
๐ค Contributing
Here's our contribution guide.
โค๏ธ Support this project
If you like this project, please consider supporting it by buying my a coffee!
Made with โค๏ธ by Jonathan Bakebwa ๐บ๐ฌ