pubber
v1.2.0
Published
A pubsub library for subscriptions, dispatchers and unsubscribing.
Downloads
3
Maintainers
Readme
Pubber
Pubber is an ES6 module for implementing pubsub in a project. It exposes three methods:
- subscribe - function to subscribe to a topic
- dispatch - function to send a topic with optional data
- unsubscribe - function to delete a subscriber
Installation
In your terminal, run:
npm i -D pubber
Import in Project
After installing, you need to import Pubber into your project. Remember, this is an ES6 module, so you need to use ES6 import syntax.
import {subscribe, dispatch, unsubscribe} from 'pubber'
After importing, you can define subscribers and disptach topics and data. You can define a subscriber wherever it makes sense for your code.
Create a Subscriber
The subscribe
function takes up to three arguments, a topic, a callback and an optional truthy value. The callback will be executed when the topic gets disptached. The callback can capture a default parameter representing any data that was dispatched with the topic:
// ...bunch of code...
// Define a subscriber:
subscribe('announcement', (msg) => alert(`The message is: ${msg}`))
In the above subscriber it's obvious that it is expecting a string as data. Even so, it is best to allays check the type of data the subscriber receives before attempting to use it. This will help you avoid unexpected type bugs. Here's the subscriber redone with a type check:
// ...bunch of code...
// Define a subscriber:
subscribe('announcement', (msg) => {
typeof msg === 'string' && alert(`The message is: ${msg}`)
})
Now, it the wrong type was dispatched, the subscribe will ignore it. We could also modify this to exepct a string or a boolean.
Force a Subscriber to Run Only Once
As was mentioned, a subscriber can take a third optional value, which should be truthy. Internally this is called "once" and it determines whether the subscription should be called only once. When you provide this third value and it is truthy, the subscriber will unsubscribe itself after executing. If this third argument is not provided, as in all the previous examples, the subscriber will execute each time a dispatch occurs.
Below is an example of providing a third argument to a subscriber to force it to run only one time:
// Define a subscriber that will fire only once.
// Notice that we pass the value "true" as the last argument:
subscribe(
'announcement',
(msg) => {
typeof msg === 'string' && alert(`The message is: ${msg}`)
},
/* Force the subscriber to run only once. */
true
)
Subscriber Without Data
A subscriber does not need to receive data. You could define a subscribe that just listens for a topic and then runs. Here's the previous subscriber refactored to work without data:
// ...bunch of code...
// Define a subscriber:
subscribe('announcement', () => alert('Just heard an announcement!'))
With the above change, even if we dispatch 'announcement' with data, it will ignore the data and make the alert.
Creating a Dispatcher
The dispatch
function takes one argument, with a second one being optional: topic and data. This means you can dispatch a topic without data. You can define dispatcher where it makes sense. For example, you could have a user event and use a dispatch to notify some other part of your application. You could dispatch just the topic, or a topic with data. It toally depends on your needs.
Dispatch Without Data
dispatch('announcement')
// The previous defined subscribers would react to this dispatch.
// Dispatch a message for the previous subscriber:
dispatch('announcement', 'Hello from over here!')
Complex Data
So far we saw how to use primitive data types. You could use complex data, such as an object or an array. Always use a type check before using any type of data.
In this example we are going to subscribe to a topic that expects and object and then dispatch one:
// Somewhere in your code:
subscribe('new-person', (person) => {
// Check that person is not an array but is an object:
if (!Array.isArray(person) && typeof person === 'object') {
alert(`We have a new person: ${person.name}!`)
}
})
// Elsewhere in your code an user interaction occurs:
dispatch('new-person', {
id: '1234',
name: 'Joe Bodoni',
job: 'mechanic'
})
// This dispatch will be received by the subscriber, which will alert: "We have a new person: Joe Bodoni!"
Unsubscribe
If you need to, you can unsubscribe a topic. Since there may be multiple subscribers listening to the same topic, this will disable all subscriptions to that topic:
unsubscribe('announcement')
In Browser
You can use Pubber in the browser. Just import it with a script tag pointing to the online version:
<script src="https://unpkg.com/[email protected]/dist/index.js"></script>
The online version is in umd
format, so the functions are namespaced to pubber
. After importing Pubber with a script tag, you can use it like this:
<script>
// Grab functions from global Pubber object:
const {subscribe, dispatch} = pubber
subscribe('bozo', (data) => {
alert(`This is the data: ${data}`)
})
// Enable a dispatch:
document.querySelector('button').addEventListener('click', () => dispatch('bozo', 'This is Bozo the Clown!'))
</script>